sf-crud 12.0.2 → 12.0.4
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 +67 -21
- package/bundles/sf-crud.umd.js.map +1 -1
- package/esm2015/lib/components/control/control.component.js +3 -3
- package/esm2015/lib/components/registro/registro.component.js +30 -12
- package/esm2015/lib/components/registro-child/registro-child.component.js +28 -8
- package/fesm2015/sf-crud.js +58 -20
- package/fesm2015/sf-crud.js.map +1 -1
- package/lib/components/registro/registro.component.d.ts +1 -0
- package/lib/components/registro-child/registro-child.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -43,10 +43,11 @@ export class RegistroChildComponent {
|
|
|
43
43
|
var _a;
|
|
44
44
|
this.controls.push([]);
|
|
45
45
|
this.values.push([]);
|
|
46
|
-
(_a = layout.elements) === null || _a === void 0 ? void 0 : _a.forEach((element) => {
|
|
46
|
+
(_a = layout.elements) === null || _a === void 0 ? void 0 : _a.forEach((element, j) => {
|
|
47
47
|
if (!element.scope)
|
|
48
48
|
console.log("CONFIGURAR BIEN " + element);
|
|
49
49
|
this.controls[i].push(this.getControl(element.scope));
|
|
50
|
+
this.controls[i][j].scope = element.scope;
|
|
50
51
|
this.values[i].push(this.getValue(element.scope));
|
|
51
52
|
});
|
|
52
53
|
});
|
|
@@ -62,9 +63,14 @@ export class RegistroChildComponent {
|
|
|
62
63
|
switch (typeof (value)) {
|
|
63
64
|
case 'object':
|
|
64
65
|
if (Array.isArray(value))
|
|
65
|
-
value.forEach((val) =>
|
|
66
|
-
|
|
66
|
+
value.forEach((val) => {
|
|
67
|
+
this.setValueByScope(val.scope, val.value);
|
|
68
|
+
jsonpath.value(this.data, val.scope.replace('.properties', ''), val.value);
|
|
69
|
+
});
|
|
70
|
+
else {
|
|
71
|
+
this.values[i][j] = value;
|
|
67
72
|
jsonpath.value(this.data, scope.replace('.properties', ''), value);
|
|
73
|
+
}
|
|
68
74
|
break;
|
|
69
75
|
default:
|
|
70
76
|
this.values[i][j] = value;
|
|
@@ -292,11 +298,25 @@ export class RegistroChildComponent {
|
|
|
292
298
|
});
|
|
293
299
|
this.applyValuesOnEvent('onChange', this.esquema, element.scope.replace('$..properties.', ''));
|
|
294
300
|
}
|
|
301
|
+
setValueByScope(scope, newVal) {
|
|
302
|
+
for (let i = 0; i < this.controls.length; i++) {
|
|
303
|
+
const row = this.controls[i];
|
|
304
|
+
row.forEach((el, j) => {
|
|
305
|
+
if (el.scope && el.scope.replace('.properties', '') == scope.replace('.properties', '')) {
|
|
306
|
+
this.values[i][j] = newVal;
|
|
307
|
+
}
|
|
308
|
+
});
|
|
309
|
+
}
|
|
310
|
+
}
|
|
295
311
|
applyValuesFromObject(event) {
|
|
296
|
-
if (event.
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
312
|
+
if (event.optionValue) {
|
|
313
|
+
for (let i = 0; i < event.optionValue.length; i++) {
|
|
314
|
+
const optionVal = event.optionValue[i];
|
|
315
|
+
const newVal = event.data ? this.aplyFormatValue(optionVal.scope, event.data[optionVal.key]) : null;
|
|
316
|
+
jsonpath.value(this.data, optionVal.scope.replace('.properties', ''), this.aplyFormatValue(optionVal.scope, event.data[optionVal.key]));
|
|
317
|
+
this.setValueByScope(optionVal.scope, newVal);
|
|
318
|
+
}
|
|
319
|
+
}
|
|
300
320
|
}
|
|
301
321
|
aplyFormatValue(scope, value) {
|
|
302
322
|
let control = jsonpath.query(this.esquema, scope)[0];
|
|
@@ -325,4 +345,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
325
345
|
providers: [MessageService, DialogService]
|
|
326
346
|
}]
|
|
327
347
|
}], ctorParameters: function () { return [{ type: i1.DynamicDialogRef }, { type: i1.DynamicDialogConfig }, { type: i2.MessageService }, { type: i1.DialogService }]; } });
|
|
328
|
-
//# 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';\r\nimport { DialogService,DynamicDialogConfig, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { Shema } from '../../shared/models/shema.model';\r\nimport * as jsonpath from 'jsonpath';\r\nimport { Message, MessageService } from 'primeng/api';\r\nimport * as moment from 'moment';\r\nimport { RegistroDetalleComponent } from '../registro-detalle/registro-detalle.component';\r\n\r\n@Component({\r\n  selector: 'lib-registro-child',\r\n  templateUrl: './registro-child.component.html',\r\n  providers: [MessageService,DialogService]\r\n})\r\nexport class RegistroChildComponent implements OnInit {\r\n\r\n  public uiEsquema: any;\r\n  public esquema: Shema = new Shema();\r\n  public data: any;\r\n  public dialogRef?: DynamicDialogRef;\r\n  public trx: string = 'c';\r\n  values!: any[][];\r\n  controls!: any[][];\r\n  controlsLoaded = false;\r\n\r\n  constructor(\r\n    public ref: DynamicDialogRef,\r\n    public config: DynamicDialogConfig,\r\n    private messageService: MessageService,\r\n    private dialogService: DialogService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.uiEsquema = this.config.data.uiEsquema[0];\r\n    this.esquema = this.config.data.esquema;\r\n    this.data = this.config.data?.data;\r\n    if (!this.data) {\r\n      this.data = this.createObject(this.esquema);\r\n      jsonpath.value(this.data, '$..id', this.config.data.id);\r\n    }\r\n    this.buildControls()\r\n  }\r\n\r\n    buildControls(){\r\n      this.controlsLoaded = false;\r\n      this.controls = []\r\n      this.values = []\r\n      this.uiEsquema.elements.forEach((layout: any, i: number) => {\r\n        this.controls.push([])\r\n        this.values.push([])\r\n\r\n        layout.elements?.forEach((element: any) => {\r\n          if (!element.scope) console.log(\"CONFIGURAR BIEN \" + element)\r\n          this.controls[i].push(this.getControl(element.scope))\r\n          this.values[i].push(this.getValue(element.scope))\r\n        });\r\n      });\r\n      this.controlsLoaded = true;\r\n  }\r\n\r\n  getControl(scope: string) {\r\n    return jsonpath.query(this.esquema, scope)[0];\r\n  }\r\n\r\n  getValue(scope: string) {\r\n    return jsonpath.query(this.data, scope.replace('.properties', ''))[0];\r\n  }\r\n\r\n  setValue(value: any, scope: string, i: number, j: number) {\r\n    switch (typeof (value)) {\r\n      case 'object':\r\n        if (Array.isArray(value)) value.forEach((val: any) => jsonpath.value(this.data, val.scope.replace('.properties', ''), val.value))\r\n        else jsonpath.value(this.data, scope.replace('.properties', ''), value);\r\n        break;\r\n      default:\r\n        this.values[i][j] = value;\r\n        jsonpath.value(this.data, scope.replace('.properties', ''), value);\r\n        break;\r\n    }\r\n    this.applyValuesOnEvent('onChange', this.esquema, scope.replace('$..properties.', ''));\r\n  }\r\n\r\n  createObject(esquema: Shema) {\r\n    let object = {};\r\n    const resultArray: any[] = [];\r\n    switch (esquema.type) {\r\n      case 'numeric':\r\n        return esquema?.default || 0;\r\n      case 'string':\r\n      case 'date':\r\n        return esquema?.default ? this.setDefaultValue(esquema.default) : null;\r\n      case 'boolean':\r\n        return esquema?.default || false;\r\n      case 'file':\r\n        return null;\r\n      case 'array':\r\n      case 'object':\r\n        for (const key in esquema?.properties) {\r\n          Object.defineProperty(object, key, { value: this.createObjectChild(esquema?.properties[key]), writable: true, enumerable: true, configurable: true })\r\n        }\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n    return object;\r\n  }\r\n\r\n  createObjectChild(esquema: Shema) {\r\n    let object = {};\r\n    const resultArray: any[] = [];\r\n    switch (esquema.type) {\r\n      case 'numeric':\r\n        return esquema?.default || 0;\r\n      case 'string':\r\n      case 'date':\r\n        return esquema?.default ? this.setDefaultValue(esquema.default) : null;\r\n      case 'boolean':\r\n        return esquema?.default || false;\r\n      case 'file':\r\n        return null;\r\n      case 'array':\r\n        return [];\r\n      case 'object':\r\n        for (const key in esquema?.properties) {\r\n          Object.defineProperty(object, key, { value: this.createObject(esquema?.properties[key]), writable: true, enumerable: true, configurable: true })\r\n        }\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n    return object;\r\n  }\r\n\r\n  setDefaultValue(value: string) {\r\n    let data = null;\r\n    let uactivo;\r\n    switch (value) {\r\n      case '@uactivo':\r\n        uactivo = JSON.parse(localStorage.getItem('oSessionTFM') || '{}')\r\n        if (!uactivo) console.log('Validar configuracion de sesion')\r\n        else data = `${uactivo.UsuarioSistema.TDOC}-${uactivo.UsuarioSistema.NDOC}`\r\n        break;\r\n      case '@tdocactivo':\r\n        uactivo = JSON.parse(sessionStorage.getItem('usrSesion') || '{}')\r\n        if (!uactivo) console.log('Validar configuracion de sesion')\r\n        else data = uactivo.UsuarioSistema.TDOC\r\n        break;\r\n      case '@ndocactivo':\r\n        uactivo = JSON.parse(sessionStorage.getItem('usrSesion') || '{}')\r\n        if (!uactivo) console.log('Validar configuracion de sesion')\r\n        else data = uactivo.UsuarioSistema.NDOC\r\n        break;\r\n      case '@hoy':\r\n        data = new Date();\r\n        break;\r\n      default:\r\n        data = value;\r\n        break;\r\n    }\r\n    return data\r\n  }\r\n\r\n  submit() {\r\n    this.applyValuesOnEvent('onSubmit', this.esquema);\r\n    if (!this.validateData()) return;\r\n    this.ref.close(this.data);\r\n  }\r\n\r\n  cancel() {\r\n    this.applyValuesOnEvent('onCancel', this.esquema);\r\n    this.ref.close();\r\n  }\r\n\r\n  validateData() {\r\n    if (this.esquema.validations.type == 'local') return this.validateDataLocal();\r\n    return true;\r\n  }\r\n\r\n  validateDataLocal() {\r\n    let err: string[] = []\r\n    this.esquema.validations.required.forEach((x: any) => {\r\n      if (!jsonpath.query(this.data, x.field)[0]) err.push(x.message);\r\n    })\r\n    if (err.length != 0) this.messageService.add({ severity: 'warn', detail: err.join('. ') })\r\n    return err.length == 0;\r\n  }\r\n\r\n  applyValuesOnEvent(event: string, esquema: Shema, scope?: string) {\r\n    if (scope) {\r\n      if (esquema.properties[scope][event]) {\r\n        esquema.properties[scope][event].forEach((value: any) => {\r\n          this.setValueEvent(this.data, value)\r\n        })\r\n      }\r\n    } else {\r\n      for (const key in esquema.properties) {\r\n        if (esquema.properties[key][event]) {\r\n          esquema.properties[key][event].forEach((value: any) => {\r\n            this.setValueEvent(this.data, value)\r\n          })\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  setValueEvent(data: any, params: { op: string, scope: string[], key: any, separator: string }) {\r\n    let value;\r\n    let date = moment(new Date());\r\n    switch (params.op) {\r\n      case 'sum':\r\n        value = jsonpath.query(data, params?.scope[0]).reduce((acc, cur) => acc += params?.key ? cur[params.key] : cur, 0)\r\n        break;\r\n      case 'concat':\r\n        let array: string[] = []\r\n        params?.key?.reduce((acc: any[], cur: string) => {\r\n          array.push(jsonpath.query(data, cur)[0])\r\n        }, [])\r\n        if (params?.separator) jsonpath.value(data, params.scope[0], array.join(params?.separator || ' '))\r\n        break;\r\n      case 'enable':\r\n        jsonpath.value(this.esquema, params.scope[0], false)\r\n        break;\r\n      case 'disabled':\r\n        jsonpath.value(this.esquema, params.scope[0], true)\r\n        break;\r\n      case 'replace:endpoint':\r\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}`)))\r\n        break;\r\n      case 'setNull':\r\n        jsonpath.value(this.data, `$.${params.key}`, null);\r\n        break;\r\n      case 'datediff:years':\r\n        jsonpath.value(this.data, params.scope[0], date.diff(moment(jsonpath.query(this.data, params.scope[1])[0]), 'years'))\r\n        break;\r\n      case 'datediff:months':\r\n        jsonpath.value(this.data, params.scope[0], date.diff(moment(jsonpath.query(this.data, params.scope[1])[0]), 'months'))\r\n        break;\r\n      case 'datediff:weeks':\r\n        jsonpath.value(this.data, params.scope[0], date.diff(moment(jsonpath.query(this.data, params.scope[1])[0]), 'weeks'))\r\n        break;\r\n      case 'datediff:days':\r\n        jsonpath.value(this.data, params.scope[0], date.diff(moment(jsonpath.query(this.data, params.scope[1])[0]), 'days'))\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n    return value;\r\n  }\r\n\r\n  sendNotification(message: Message) {\r\n    this.messageService.add(message)\r\n  }\r\n\r\n  addObjectArray(element: any) {\r\n    this.dialogRef = this.dialogService.open(RegistroDetalleComponent, {\r\n      header: element.label ? element.label : 'Detalle',\r\n      width: '70%',\r\n      modal: true,\r\n      closable: false,\r\n      data: {\r\n        uiEsquema: { ...element.elements },\r\n        esquema: this.getControl(element.scope),\r\n        id: this.getValue(element.scope).length + 1\r\n      }\r\n    })\r\n    this.dialogRef.onClose.subscribe((data: any) => {\r\n      if (data) this.data[element.scope.replace('$..properties.', '')].push(data);\r\n       this.applyValuesOnEvent('onChange', this.esquema, element.scope.replace('$..properties.', ''))\r\n    })\r\n  }\r\n\r\n  editRow(element: any, data: any, index: number) {\r\n    this.dialogRef = this.dialogService.open(RegistroDetalleComponent, {\r\n      header: element.label ? element.label : 'Detalle',\r\n      width: '70%',\r\n      modal: true,\r\n      closable: false,\r\n      data: {\r\n        uiEsquema: { ...element.elements },\r\n        esquema: this.getControl(element.scope),\r\n        data: { ...data }\r\n      }\r\n    })\r\n    this.dialogRef.onClose.subscribe((data: any) => {\r\n      if (data) this.data[element.scope.replace('$..properties.', '')][index] = data;\r\n      this.applyValuesOnEvent('onChange', this.esquema, element.scope.replace('$..properties.', ''))\r\n    })\r\n  }\r\n\r\n  deleteRow(element: any, index: number) {\r\n    this.data[element.scope.replace('$..properties.', '')].splice(index, 1);\r\n    index = 1;\r\n    this.data[element.scope.replace('$..properties.', '')].forEach((el: any) => {\r\n      el.id = index;\r\n      index++;\r\n    })\r\n    this.applyValuesOnEvent('onChange', this.esquema, element.scope.replace('$..properties.', ''))\r\n  }\r\n\r\n  applyValuesFromObject(event: any) {\r\n    if (event.data) event.optionValue.forEach((value: any) => jsonpath.value(this.data, value.scope.replace('.properties',''), this.aplyFormatValue(value.scope, event.data[value.key])));\r\n    else event.optionValue.forEach((value: any) => jsonpath.value(this.data, value.scope.replace('.properties',''), null));\r\n  }\r\n  aplyFormatValue(scope: string, value: any) {\r\n    let 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","<p-toast></p-toast>\r\n<div *ngIf=\"controlsLoaded\">\r\n<div *ngFor=\"let element of uiEsquema.elements; let i = index\" [class]=\"element?.class\" #a>\r\n    <ng-container [ngSwitch]=\"element.type\">\r\n        <div *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\">\r\n                    <sf-control *ngSwitchCase=\"'Control'\" [control]=\"controls[i][j]\" [label]=\"el.label\" [value]=\"values[i][j]\"\r\n                        (setValue)=\"setValue($event, el.scope, i, j)\" (sendNotification)=\"sendNotification($event)\"\r\n                        (sendObject)=\"applyValuesFromObject($event)\"></sf-control>\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 k =index\" [class]=\"el?.class\">\r\n                <ng-container [ngSwitch]=\"el.type\">\r\n                    <sf-control *ngSwitchCase=\"'Control'\" [control]=\"controls[i][k]\" [label]=\"el.label\"\r\n                        [value]=\"values[i][k]\" (setValue)=\"setValue($event, el.scope, i, k)\"\r\n                        (sendNotification)=\"sendNotification($event)\"\r\n                        (sendObject)=\"applyValuesFromObject($event)\"></sf-control>\r\n                    <ng-container *ngSwitchCase=\"'Table'\">\r\n                        <p-table [value]=\"getValue(el.scope)\" [columns]=\"getControl(el.scope).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\"></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 *ngIf=\"trx == 'c' || trx == 'u'\">\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=\"'text'\">\r\n                                            <td>{{rowData[col.col]}}</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 *ngIf=\"trx == 'c' || trx == 'u'\">\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)\"\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 *ngSwitchCase=\"'Control'\">\r\n            <sf-control [control]=\"getControl(element.scope)\" [label]=\"element.label\"></sf-control>\r\n        </ng-container>\r\n    </ng-container>\r\n</div>\r\n<div class=\"card-footer mt-2\">\r\n    <button pButton pRipple type=\"button\" label=\"Guardar\" (click)=\"submit()\" class=\"mr-2\"></button>\r\n    <button pButton pRipple type=\"button\" label=\"Cancelar\" (click)=\"cancel()\" class=\"p-button-danger\"></button>\r\n</div>\r\n</div>\r\n"]}
|
|
348
|
+
//# 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';\r\nimport { DialogService,DynamicDialogConfig, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { Shema } from '../../shared/models/shema.model';\r\nimport * as jsonpath from 'jsonpath';\r\nimport { Message, MessageService } from 'primeng/api';\r\nimport * as moment from 'moment';\r\nimport { RegistroDetalleComponent } from '../registro-detalle/registro-detalle.component';\r\n\r\n@Component({\r\n  selector: 'lib-registro-child',\r\n  templateUrl: './registro-child.component.html',\r\n  providers: [MessageService,DialogService]\r\n})\r\nexport class RegistroChildComponent implements OnInit {\r\n\r\n  public uiEsquema: any;\r\n  public esquema: Shema = new Shema();\r\n  public data: any;\r\n  public dialogRef?: DynamicDialogRef;\r\n  public trx: string = 'c';\r\n  values!: any[][];\r\n  controls!: any[][];\r\n  controlsLoaded = false;\r\n\r\n  constructor(\r\n    public ref: DynamicDialogRef,\r\n    public config: DynamicDialogConfig,\r\n    private messageService: MessageService,\r\n    private dialogService: DialogService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.uiEsquema = this.config.data.uiEsquema[0];\r\n    this.esquema = this.config.data.esquema;\r\n    this.data = this.config.data?.data;\r\n    if (!this.data) {\r\n      this.data = this.createObject(this.esquema);\r\n      jsonpath.value(this.data, '$..id', this.config.data.id);\r\n    }\r\n    this.buildControls()\r\n  }\r\n\r\n    buildControls(){\r\n      this.controlsLoaded = false;\r\n      this.controls = []\r\n      this.values = []\r\n      this.uiEsquema.elements.forEach((layout: any, i: number) => {\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.scope) console.log(\"CONFIGURAR BIEN \" + element)\r\n          this.controls[i].push(this.getControl(element.scope))\r\n          this.controls[i][j].scope = element.scope\r\n          this.values[i].push(this.getValue(element.scope))\r\n        });\r\n      });\r\n      this.controlsLoaded = true;\r\n  }\r\n\r\n  getControl(scope: string) {\r\n    return jsonpath.query(this.esquema, scope)[0];\r\n  }\r\n\r\n  getValue(scope: string) {\r\n    return jsonpath.query(this.data, scope.replace('.properties', ''))[0];\r\n  }\r\n\r\n  setValue(value: any, scope: string, i: number, j: number) {\r\n    switch (typeof (value)) {\r\n      case 'object':\r\n        if (Array.isArray(value)) value.forEach((val: any) => {\r\n          this.setValueByScope(val.scope, val.value)\r\n          jsonpath.value(this.data, val.scope.replace('.properties', ''), val.value)\r\n        })\r\n        else {\r\n          this.values[i][j] = value;\r\n          jsonpath.value(this.data, scope.replace('.properties', ''), value);\r\n        }\r\n        break;\r\n      default:\r\n        this.values[i][j] = value;\r\n        jsonpath.value(this.data, scope.replace('.properties', ''), value);\r\n        break;\r\n    }\r\n    this.applyValuesOnEvent('onChange', this.esquema, scope.replace('$..properties.', ''));\r\n  }\r\n\r\n  createObject(esquema: Shema) {\r\n    let object = {};\r\n    const resultArray: any[] = [];\r\n    switch (esquema.type) {\r\n      case 'numeric':\r\n        return esquema?.default || 0;\r\n      case 'string':\r\n      case 'date':\r\n        return esquema?.default ? this.setDefaultValue(esquema.default) : null;\r\n      case 'boolean':\r\n        return esquema?.default || false;\r\n      case 'file':\r\n        return null;\r\n      case 'array':\r\n      case 'object':\r\n        for (const key in esquema?.properties) {\r\n          Object.defineProperty(object, key, { value: this.createObjectChild(esquema?.properties[key]), writable: true, enumerable: true, configurable: true })\r\n        }\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n    return object;\r\n  }\r\n\r\n  createObjectChild(esquema: Shema) {\r\n    let object = {};\r\n    const resultArray: any[] = [];\r\n    switch (esquema.type) {\r\n      case 'numeric':\r\n        return esquema?.default || 0;\r\n      case 'string':\r\n      case 'date':\r\n        return esquema?.default ? this.setDefaultValue(esquema.default) : null;\r\n      case 'boolean':\r\n        return esquema?.default || false;\r\n      case 'file':\r\n        return null;\r\n      case 'array':\r\n        return [];\r\n      case 'object':\r\n        for (const key in esquema?.properties) {\r\n          Object.defineProperty(object, key, { value: this.createObject(esquema?.properties[key]), writable: true, enumerable: true, configurable: true })\r\n        }\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n    return object;\r\n  }\r\n\r\n  setDefaultValue(value: string) {\r\n    let data = null;\r\n    let uactivo;\r\n    switch (value) {\r\n      case '@uactivo':\r\n        uactivo = JSON.parse(localStorage.getItem('oSessionTFM') || '{}')\r\n        if (!uactivo) console.log('Validar configuracion de sesion')\r\n        else data = `${uactivo.UsuarioSistema.TDOC}-${uactivo.UsuarioSistema.NDOC}`\r\n        break;\r\n      case '@tdocactivo':\r\n        uactivo = JSON.parse(sessionStorage.getItem('usrSesion') || '{}')\r\n        if (!uactivo) console.log('Validar configuracion de sesion')\r\n        else data = uactivo.UsuarioSistema.TDOC\r\n        break;\r\n      case '@ndocactivo':\r\n        uactivo = JSON.parse(sessionStorage.getItem('usrSesion') || '{}')\r\n        if (!uactivo) console.log('Validar configuracion de sesion')\r\n        else data = uactivo.UsuarioSistema.NDOC\r\n        break;\r\n      case '@hoy':\r\n        data = new Date();\r\n        break;\r\n      default:\r\n        data = value;\r\n        break;\r\n    }\r\n    return data\r\n  }\r\n\r\n  submit() {\r\n    this.applyValuesOnEvent('onSubmit', this.esquema);\r\n    if (!this.validateData()) return;\r\n    this.ref.close(this.data);\r\n  }\r\n\r\n  cancel() {\r\n    this.applyValuesOnEvent('onCancel', this.esquema);\r\n    this.ref.close();\r\n  }\r\n\r\n  validateData() {\r\n    if (this.esquema.validations.type == 'local') return this.validateDataLocal();\r\n    return true;\r\n  }\r\n\r\n  validateDataLocal() {\r\n    let err: string[] = []\r\n    this.esquema.validations.required.forEach((x: any) => {\r\n      if (!jsonpath.query(this.data, x.field)[0]) err.push(x.message);\r\n    })\r\n    if (err.length != 0) this.messageService.add({ severity: 'warn', detail: err.join('. ') })\r\n    return err.length == 0;\r\n  }\r\n\r\n  applyValuesOnEvent(event: string, esquema: Shema, scope?: string) {\r\n    if (scope) {\r\n      if (esquema.properties[scope][event]) {\r\n        esquema.properties[scope][event].forEach((value: any) => {\r\n          this.setValueEvent(this.data, value)\r\n        })\r\n      }\r\n    } else {\r\n      for (const key in esquema.properties) {\r\n        if (esquema.properties[key][event]) {\r\n          esquema.properties[key][event].forEach((value: any) => {\r\n            this.setValueEvent(this.data, value)\r\n          })\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  setValueEvent(data: any, params: { op: string, scope: string[], key: any, separator: string }) {\r\n    let value;\r\n    let date = moment(new Date());\r\n    switch (params.op) {\r\n      case 'sum':\r\n        value = jsonpath.query(data, params?.scope[0]).reduce((acc, cur) => acc += params?.key ? cur[params.key] : cur, 0)\r\n        break;\r\n      case 'concat':\r\n        let array: string[] = []\r\n        params?.key?.reduce((acc: any[], cur: string) => {\r\n          array.push(jsonpath.query(data, cur)[0])\r\n        }, [])\r\n        if (params?.separator) jsonpath.value(data, params.scope[0], array.join(params?.separator || ' '))\r\n        break;\r\n      case 'enable':\r\n        jsonpath.value(this.esquema, params.scope[0], false)\r\n        break;\r\n      case 'disabled':\r\n        jsonpath.value(this.esquema, params.scope[0], true)\r\n        break;\r\n      case 'replace:endpoint':\r\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}`)))\r\n        break;\r\n      case 'setNull':\r\n        jsonpath.value(this.data, `$.${params.key}`, null);\r\n        break;\r\n      case 'datediff:years':\r\n        jsonpath.value(this.data, params.scope[0], date.diff(moment(jsonpath.query(this.data, params.scope[1])[0]), 'years'))\r\n        break;\r\n      case 'datediff:months':\r\n        jsonpath.value(this.data, params.scope[0], date.diff(moment(jsonpath.query(this.data, params.scope[1])[0]), 'months'))\r\n        break;\r\n      case 'datediff:weeks':\r\n        jsonpath.value(this.data, params.scope[0], date.diff(moment(jsonpath.query(this.data, params.scope[1])[0]), 'weeks'))\r\n        break;\r\n      case 'datediff:days':\r\n        jsonpath.value(this.data, params.scope[0], date.diff(moment(jsonpath.query(this.data, params.scope[1])[0]), 'days'))\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n    return value;\r\n  }\r\n\r\n  sendNotification(message: Message) {\r\n    this.messageService.add(message)\r\n  }\r\n\r\n  addObjectArray(element: any) {\r\n    this.dialogRef = this.dialogService.open(RegistroDetalleComponent, {\r\n      header: element.label ? element.label : 'Detalle',\r\n      width: '70%',\r\n      modal: true,\r\n      closable: false,\r\n      data: {\r\n        uiEsquema: { ...element.elements },\r\n        esquema: this.getControl(element.scope),\r\n        id: this.getValue(element.scope).length + 1\r\n      }\r\n    })\r\n    this.dialogRef.onClose.subscribe((data: any) => {\r\n      if (data) this.data[element.scope.replace('$..properties.', '')].push(data);\r\n       this.applyValuesOnEvent('onChange', this.esquema, element.scope.replace('$..properties.', ''))\r\n    })\r\n  }\r\n\r\n  editRow(element: any, data: any, index: number) {\r\n    this.dialogRef = this.dialogService.open(RegistroDetalleComponent, {\r\n      header: element.label ? element.label : 'Detalle',\r\n      width: '70%',\r\n      modal: true,\r\n      closable: false,\r\n      data: {\r\n        uiEsquema: { ...element.elements },\r\n        esquema: this.getControl(element.scope),\r\n        data: { ...data }\r\n      }\r\n    })\r\n    this.dialogRef.onClose.subscribe((data: any) => {\r\n      if (data) this.data[element.scope.replace('$..properties.', '')][index] = data;\r\n      this.applyValuesOnEvent('onChange', this.esquema, element.scope.replace('$..properties.', ''))\r\n    })\r\n  }\r\n\r\n  deleteRow(element: any, index: number) {\r\n    this.data[element.scope.replace('$..properties.', '')].splice(index, 1);\r\n    index = 1;\r\n    this.data[element.scope.replace('$..properties.', '')].forEach((el: any) => {\r\n      el.id = index;\r\n      index++;\r\n    })\r\n    this.applyValuesOnEvent('onChange', this.esquema, element.scope.replace('$..properties.', ''))\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  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  aplyFormatValue(scope: string, value: any) {\r\n    let 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","<p-toast></p-toast>\r\n<div *ngIf=\"controlsLoaded\">\r\n<div *ngFor=\"let element of uiEsquema.elements; let i = index\" [class]=\"element?.class\" #a>\r\n    <ng-container [ngSwitch]=\"element.type\">\r\n        <div *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\">\r\n                    <sf-control *ngSwitchCase=\"'Control'\" [control]=\"controls[i][j]\" [label]=\"el.label\" [value]=\"values[i][j]\"\r\n                        (setValue)=\"setValue($event, el.scope, i, j)\" (sendNotification)=\"sendNotification($event)\"\r\n                        (sendObject)=\"applyValuesFromObject($event)\"></sf-control>\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 k =index\" [class]=\"el?.class\">\r\n                <ng-container [ngSwitch]=\"el.type\">\r\n                    <sf-control *ngSwitchCase=\"'Control'\" [control]=\"controls[i][k]\" [label]=\"el.label\"\r\n                        [value]=\"values[i][k]\" (setValue)=\"setValue($event, el.scope, i, k)\"\r\n                        (sendNotification)=\"sendNotification($event)\"\r\n                        (sendObject)=\"applyValuesFromObject($event)\"></sf-control>\r\n                    <ng-container *ngSwitchCase=\"'Table'\">\r\n                        <p-table [value]=\"getValue(el.scope)\" [columns]=\"getControl(el.scope).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\"></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 *ngIf=\"trx == 'c' || trx == 'u'\">\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=\"'text'\">\r\n                                            <td>{{rowData[col.col]}}</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 *ngIf=\"trx == 'c' || trx == 'u'\">\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)\"\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 *ngSwitchCase=\"'Control'\">\r\n            <sf-control [control]=\"getControl(element.scope)\" [label]=\"element.label\"></sf-control>\r\n        </ng-container>\r\n    </ng-container>\r\n</div>\r\n<div class=\"card-footer mt-2\">\r\n    <button pButton pRipple type=\"button\" label=\"Guardar\" (click)=\"submit()\" class=\"mr-2\"></button>\r\n    <button pButton pRipple type=\"button\" label=\"Cancelar\" (click)=\"cancel()\" class=\"p-button-danger\"></button>\r\n</div>\r\n</div>\r\n"]}
|
package/fesm2015/sf-crud.js
CHANGED
|
@@ -466,14 +466,14 @@ class ControlComponent {
|
|
|
466
466
|
}
|
|
467
467
|
setDate() {
|
|
468
468
|
let format = this.control.formatMoment;
|
|
469
|
-
if (format && this.value) {
|
|
469
|
+
if (format && this.value && !(this.value instanceof Date)) {
|
|
470
470
|
this.value = moment(this.value, format).toDate();
|
|
471
471
|
this.sendValue();
|
|
472
472
|
}
|
|
473
473
|
}
|
|
474
474
|
}
|
|
475
475
|
ControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ControlComponent, deps: [{ token: GeneralService }], target: i0.ɵɵFactoryTarget.Component });
|
|
476
|
-
ControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: ControlComponent, selector: "sf-control", inputs: { control: "control", label: "label", value: "value", appendTo: "appendTo" }, outputs: { setValue: "setValue", sendNotification: "sendNotification", sendObject: "sendObject" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"control.type\" #cc>\r\n <label [for]=\"label\" style=\"width: -webkit-fill-available;\">{{label}}</label>\r\n <ng-container *ngSwitchCase=\"'string'\">\r\n <ng-container [ngSwitch]=\"control.subtype\">\r\n <ng-container *ngSwitchCase=\"'input'\">\r\n <input pInputText type=\"text\" [(ngModel)]=\"value\" (focusout)=\"sendValue()\"\r\n [disabled]=\"control?.disabled || false\">\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'textarea'\">\r\n <textarea [rows]=\"control?.rows ? control.rows : 4\" \r\n [(ngModel)]=\"value\" (focusout)=\"sendValue()\" pInputTextarea \r\n [disabled]=\"control?.disabled || false\" [autoResize]=\"control?.autoresize || false\"></textarea>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'password'\">\r\n <input pInputText type=\"password\" [(ngModel)]=\"value\" (focusout)=\"sendValue()\"\r\n [disabled]=\"control?.disabled || false\">\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'email'\">\r\n <input pInputText type=\"text\" [(ngModel)]=\"value\" placeholder=\"email@example.com\"\r\n (focusout)=\"validateValue('email')\" [disabled]=\"control?.disabled || false\">\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'phone'\">\r\n <p-inputMask mask=\"(999) 999-9999\" [(ngModel)]=\"value\" placeholder=\"(999) 999-9999\"\r\n (focusout)=\"sendValue()\" [disabled]=\"control?.disabled || false\" [unmask]=\"control.unmask || false\"></p-inputMask>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'enum'\">\r\n <p-dropdown [options]=\"control.enum\" [(ngModel)]=\"value\" (onChange)=\"sendValue()\" appendTo=\"body\"\r\n placeholder=\"Seleccione una opci\u00F3n\" [disabled]=\"control?.disabled || false\"></p-dropdown>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'dropdown'\">\r\n <p-dropdown [lazy]=\"isLoading\" [options]=\"dataFromService\" [(ngModel)]=\"value\" (onChange)=\"sendValue()\"\r\n [optionLabel]=\"control.config.optionLabel\"\r\n [optionValue]=\"control?.field || control.config.optionValue\" (onClick)=\"refresData()\"\r\n appendTo=\"body\" placeholder=\"Seleccione una opci\u00F3n\"\r\n [disabled]=\"control?.disabled || false\"></p-dropdown>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'dropdown:replace'\">\r\n <p-dropdown [lazy]=\"isLoading\" [options]=\"dataFromService\"\r\n (onChange)=\"sendValueFromObject($event.value)\" [optionLabel]=\"control.config.optionLabel\"\r\n (onClick)=\"refresData()\" appendTo=\"body\" placeholder=\"Seleccione una opci\u00F3n\"\r\n [disabled]=\"control?.disabled || false\"></p-dropdown>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'autocomplete'\">\r\n <p-autoComplete [showEmptyMessage]=\"true\" [suggestions]=\"dataFromService\" appendTo=\"body\"\r\n (completeMethod)=\"loadDataFromControlBusquedaService($event)\" [field]=\"control.field\"\r\n [minLength]=\"1\" (onSelect)=\"sendValueFromObject($event.value)\" [(ngModel)]=\"tempValue\"\r\n [disabled]=\"control?.disabled || false\"></p-autoComplete>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'input:search'\">\r\n <div class=\"p-inputgroup\">\r\n <input type=\"text\" pInputText [(ngModel)]=\"value\" (focusout)=\"sendValue()\" />\r\n <button type=\"button\" pButton icon=\"pi pi-search\" (click)=\"searchValue(value)\"></button>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <ng-container [ngSwitch]=\"control.subtype\">\r\n <ng-container *ngSwitchCase=\"'calendar'\">\r\n <p-calendar [(ngModel)]=\"value\" (onSelect)=\"sendValue()\" (onBlur)=\"sendValue()\" [monthNavigator]=\"true\"\r\n [yearNavigator]=\"true\" yearRange=\"1900:2035\" [dateFormat]=\"control?.format || 'yy-mm-dd'\"\r\n appendTo=\"body\" [disabled]=\"control?.disabled || false\" [showOnFocus]=\"!control?.hide\"\r\n [placeholder]=\"control?.placeholder || 'aaaa-mm-dd'\" [touchUI]=\"control?.touchUI || false\"\r\n [showIcon]=\"control?.showIcon || false\"></p-calendar>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'numeric'\">\r\n <ng-container [ngSwitch]=\"control.subtype\">\r\n <ng-container *ngSwitchCase=\"'currency'\">\r\n <p-inputNumber [(ngModel)]=\"value\" mode=\"currency\" [minFractionDigits]=\"control?.minFractionDigits || 0\"\r\n [min]=\"control?.min || null\" [max]=\"control?.max || null\" (focusout)=\"sendValue()\" [locale]=\"control?.locale || undefined\"\r\n [currency]=\"control?.currency || 'USD'\" [disabled]=\"control?.disabled || false\"></p-inputNumber>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'decimal'\">\r\n <p-inputNumber [(ngModel)]=\"value\" mode=\"decimal\" (focusout)=\"sendValue()\" [min]=\"control?.min || null\"\r\n [max]=\"control?.max || null\" [minFractionDigits]=\"control?.minFractionDigits || 0\" [locale]=\"control?.locale || undefined\"\r\n [disabled]=\"control?.disabled || false\"></p-inputNumber>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'percentage'\">\r\n <p-inputNumber [(ngModel)]=\"value\" suffix=\" %\" (focusout)=\"sendValue()\" [min]=\"control?.min || null\"\r\n [max]=\"control?.max || null\" [minFractionDigits]=\"control?.minFractionDigits || 2\" [locale]=\"control?.locale || undefined\"\r\n [disabled]=\"control?.disabled || false\"></p-inputNumber>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'decimal:search'\">\r\n <div class=\"p-inputgroup\">\r\n <input type=\"number\" pInputText [(ngModel)]=\"value\" (focusout)=\"sendValue()\" />\r\n <button type=\"button\" pButton icon=\"pi pi-search\" (click)=\"searchValue(value)\"></button>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'file'\">\r\n <ng-container [ngSwitch]=\"control.subtype\">\r\n <ng-container *ngSwitchCase=\"'filetmp'\">\r\n <p-fileUpload [accept]=\"control.config.accept\" [customUpload]=\"true\" (uploadHandler)=\"onUpload($event)\"\r\n [maxFileSize]=\"control.config?.maxFileSize || null\" fileLimit=\"1\">\r\n <ng-template pTemplate=\"content\">\r\n <ul *ngIf=\"uploadedFiles.length\">\r\n <li *ngFor=\"let file of uploadedFiles\">{{file.name}} - {{file.size}} bytes</li>\r\n </ul>\r\n </ng-template>\r\n </p-fileUpload>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'boolean'\">\r\n <ng-container [ngSwitch]=\"control.subtype\">\r\n <ng-container *ngSwitchCase=\"'switch'\">\r\n <p-inputSwitch [(ngModel)]=\"value\" (onChange)=\"sendValue()\" [id]=\"label\"></p-inputSwitch>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>", components: [{ type: i2$2.InputMask, selector: "p-inputMask", inputs: ["type", "slotChar", "autoClear", "style", "inputId", "styleClass", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabel", "ariaRequired", "disabled", "readonly", "unmask", "name", "required", "characterPattern", "autoFocus", "autocomplete", "mask"], outputs: ["onComplete", "onFocus", "onBlur", "onInput", "onKeydown"] }, { type: i3$1.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "virtualScroll", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "disabled", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide"] }, { type: i4$1.AutoComplete, selector: "p-autoComplete", inputs: ["minLength", "delay", "style", "panelStyle", "styleClass", "panelStyleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "readonly", "disabled", "virtualScroll", "itemSize", "maxlength", "name", "required", "size", "appendTo", "autoHighlight", "forceSelection", "type", "autoZIndex", "baseZIndex", "ariaLabel", "ariaLabelledBy", "dropdownIcon", "unique", "group", "completeOnFocus", "field", "scrollHeight", "dropdown", "showEmptyMessage", "dropdownMode", "multiple", "tabindex", "dataKey", "emptyMessage", "showTransitionOptions", "hideTransitionOptions", "autofocus", "autocomplete", "optionGroupChildren", "optionGroupLabel", "suggestions"], outputs: ["completeMethod", "onSelect", "onUnselect", "onFocus", "onBlur", "onDropdownClick", "onClear", "onKeyUp", "onShow", "onHide"] }, { type: i5$1.Calendar, selector: "p-calendar", inputs: ["style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "numberOfMonths", "view", "touchUI", "timeSeparator", "focusTrap", "firstDayOfWeek", "showTransitionOptions", "hideTransitionOptions", "tabindex", "defaultDate", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "locale"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { type: i6$1.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "step", "inputStyle", "inputStyleClass", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown"] }, { type: i7$1.FileUpload, selector: "p-fileUpload", inputs: ["name", "url", "method", "multiple", "accept", "disabled", "auto", "withCredentials", "maxFileSize", "invalidFileSizeMessageSummary", "invalidFileSizeMessageDetail", "invalidFileTypeMessageSummary", "invalidFileTypeMessageDetail", "invalidFileLimitMessageDetail", "invalidFileLimitMessageSummary", "style", "styleClass", "previewWidth", "chooseLabel", "uploadLabel", "cancelLabel", "chooseIcon", "uploadIcon", "cancelIcon", "showUploadButton", "showCancelButton", "mode", "headers", "customUpload", "fileLimit", "files"], outputs: ["onBeforeUpload", "onSend", "onUpload", "onError", "onClear", "onRemove", "onSelect", "onProgress", "uploadHandler"] }, { type: i8.InputSwitch, selector: "p-inputSwitch", inputs: ["style", "styleClass", "tabindex", "inputId", "name", "disabled", "readonly", "ariaLabelledBy"], outputs: ["onChange"] }], directives: [{ type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i10$1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i11.InputText, selector: "[pInputText]" }, { type: i10$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i10$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i12.InputTextarea, selector: "[pInputTextarea]", inputs: ["autoResize"], outputs: ["onResize"] }, { type: i9.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i10$1.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { type: i2$1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
476
|
+
ControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: ControlComponent, selector: "sf-control", inputs: { control: "control", label: "label", value: "value", appendTo: "appendTo" }, outputs: { setValue: "setValue", sendNotification: "sendNotification", sendObject: "sendObject" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"control.type\" #cc>\r\n <label [for]=\"label\" style=\"width: -webkit-fill-available;\">{{label}}</label>\r\n <ng-container *ngSwitchCase=\"'string'\">\r\n <ng-container [ngSwitch]=\"control.subtype\">\r\n <ng-container *ngSwitchCase=\"'input'\">\r\n <input pInputText type=\"text\" [(ngModel)]=\"value\" (focusout)=\"sendValue()\"\r\n [disabled]=\"control?.disabled || false\">\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'textarea'\">\r\n <textarea [rows]=\"control?.rows ? control.rows : 4\" \r\n [(ngModel)]=\"value\" (focusout)=\"sendValue()\" pInputTextarea \r\n [disabled]=\"control?.disabled || false\" [autoResize]=\"control?.autoresize || false\"></textarea>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'password'\">\r\n <input pInputText type=\"password\" [(ngModel)]=\"value\" (focusout)=\"sendValue()\"\r\n [disabled]=\"control?.disabled || false\">\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'email'\">\r\n <input pInputText type=\"text\" [(ngModel)]=\"value\" placeholder=\"email@example.com\"\r\n (focusout)=\"validateValue('email')\" [disabled]=\"control?.disabled || false\">\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'phone'\">\r\n <p-inputMask mask=\"(999) 999-9999\" [(ngModel)]=\"value\" placeholder=\"(999) 999-9999\"\r\n (focusout)=\"sendValue()\" [disabled]=\"control?.disabled || false\" [unmask]=\"control.unmask || false\"></p-inputMask>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'enum'\">\r\n <p-dropdown [options]=\"control.enum\" [(ngModel)]=\"value\" (onChange)=\"sendValue()\" appendTo=\"body\"\r\n placeholder=\"Seleccione una opci\u00F3n\" [disabled]=\"control?.disabled || false\"></p-dropdown>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'dropdown'\">\r\n <p-dropdown [lazy]=\"isLoading\" [options]=\"dataFromService\" [(ngModel)]=\"value\" (onChange)=\"sendValue()\"\r\n [optionLabel]=\"control.config.optionLabel\"\r\n [optionValue]=\"control?.field || control.config.optionValue\" (onClick)=\"refresData()\"\r\n appendTo=\"body\" placeholder=\"Seleccione una opci\u00F3n\"\r\n [disabled]=\"control?.disabled || false\"></p-dropdown>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'dropdown:replace'\">\r\n <p-dropdown [lazy]=\"isLoading\" [options]=\"dataFromService\"\r\n (onChange)=\"sendValueFromObject($event)\" [optionLabel]=\"control.config.optionLabel\"\r\n (onClick)=\"refresData()\" appendTo=\"body\" placeholder=\"Seleccione una opci\u00F3n\"\r\n [disabled]=\"control?.disabled || false\"></p-dropdown>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'autocomplete'\">\r\n <p-autoComplete [showEmptyMessage]=\"true\" [suggestions]=\"dataFromService\" appendTo=\"body\"\r\n (completeMethod)=\"loadDataFromControlBusquedaService($event)\" [field]=\"control.field\"\r\n [minLength]=\"1\" (onSelect)=\"sendValueFromObject($event)\" [(ngModel)]=\"tempValue\"\r\n [disabled]=\"control?.disabled || false\"></p-autoComplete>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'input:search'\">\r\n <div class=\"p-inputgroup\">\r\n <input type=\"text\" pInputText [(ngModel)]=\"value\" (focusout)=\"sendValue()\" />\r\n <button type=\"button\" pButton icon=\"pi pi-search\" (click)=\"searchValue(value)\"></button>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'date'\">\r\n <ng-container [ngSwitch]=\"control.subtype\">\r\n <ng-container *ngSwitchCase=\"'calendar'\">\r\n <p-calendar [(ngModel)]=\"value\" (onSelect)=\"sendValue()\" (onBlur)=\"sendValue()\" [monthNavigator]=\"true\"\r\n [yearNavigator]=\"true\" yearRange=\"1900:2035\" [dateFormat]=\"control?.format || 'yy-mm-dd'\"\r\n appendTo=\"body\" [disabled]=\"control?.disabled || false\" [showOnFocus]=\"!control?.hide\"\r\n [placeholder]=\"control?.placeholder || 'aaaa-mm-dd'\" [touchUI]=\"control?.touchUI || false\"\r\n [showIcon]=\"control?.showIcon || false\"></p-calendar>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'numeric'\">\r\n <ng-container [ngSwitch]=\"control.subtype\">\r\n <ng-container *ngSwitchCase=\"'currency'\">\r\n <p-inputNumber [(ngModel)]=\"value\" mode=\"currency\" [minFractionDigits]=\"control?.minFractionDigits || 0\"\r\n [min]=\"control?.min || null\" [max]=\"control?.max || null\" (focusout)=\"sendValue()\" [locale]=\"control?.locale || undefined\"\r\n [currency]=\"control?.currency || 'USD'\" [disabled]=\"control?.disabled || false\"></p-inputNumber>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'decimal'\">\r\n <p-inputNumber [(ngModel)]=\"value\" mode=\"decimal\" (focusout)=\"sendValue()\" [min]=\"control?.min || null\"\r\n [max]=\"control?.max || null\" [minFractionDigits]=\"control?.minFractionDigits || 0\" [locale]=\"control?.locale || undefined\"\r\n [disabled]=\"control?.disabled || false\"></p-inputNumber>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'percentage'\">\r\n <p-inputNumber [(ngModel)]=\"value\" suffix=\" %\" (focusout)=\"sendValue()\" [min]=\"control?.min || null\"\r\n [max]=\"control?.max || null\" [minFractionDigits]=\"control?.minFractionDigits || 2\" [locale]=\"control?.locale || undefined\"\r\n [disabled]=\"control?.disabled || false\"></p-inputNumber>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'decimal:search'\">\r\n <div class=\"p-inputgroup\">\r\n <input type=\"number\" pInputText [(ngModel)]=\"value\" (focusout)=\"sendValue()\" />\r\n <button type=\"button\" pButton icon=\"pi pi-search\" (click)=\"searchValue(value)\"></button>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'file'\">\r\n <ng-container [ngSwitch]=\"control.subtype\">\r\n <ng-container *ngSwitchCase=\"'filetmp'\">\r\n <p-fileUpload [accept]=\"control.config.accept\" [customUpload]=\"true\" (uploadHandler)=\"onUpload($event)\"\r\n [maxFileSize]=\"control.config?.maxFileSize || null\" fileLimit=\"1\">\r\n <ng-template pTemplate=\"content\">\r\n <ul *ngIf=\"uploadedFiles.length\">\r\n <li *ngFor=\"let file of uploadedFiles\">{{file.name}} - {{file.size}} bytes</li>\r\n </ul>\r\n </ng-template>\r\n </p-fileUpload>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'boolean'\">\r\n <ng-container [ngSwitch]=\"control.subtype\">\r\n <ng-container *ngSwitchCase=\"'switch'\">\r\n <p-inputSwitch [(ngModel)]=\"value\" (onChange)=\"sendValue()\" [id]=\"label\"></p-inputSwitch>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>", components: [{ type: i2$2.InputMask, selector: "p-inputMask", inputs: ["type", "slotChar", "autoClear", "style", "inputId", "styleClass", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabel", "ariaRequired", "disabled", "readonly", "unmask", "name", "required", "characterPattern", "autoFocus", "autocomplete", "mask"], outputs: ["onComplete", "onFocus", "onBlur", "onInput", "onKeydown"] }, { type: i3$1.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "virtualScroll", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "disabled", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide"] }, { type: i4$1.AutoComplete, selector: "p-autoComplete", inputs: ["minLength", "delay", "style", "panelStyle", "styleClass", "panelStyleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "readonly", "disabled", "virtualScroll", "itemSize", "maxlength", "name", "required", "size", "appendTo", "autoHighlight", "forceSelection", "type", "autoZIndex", "baseZIndex", "ariaLabel", "ariaLabelledBy", "dropdownIcon", "unique", "group", "completeOnFocus", "field", "scrollHeight", "dropdown", "showEmptyMessage", "dropdownMode", "multiple", "tabindex", "dataKey", "emptyMessage", "showTransitionOptions", "hideTransitionOptions", "autofocus", "autocomplete", "optionGroupChildren", "optionGroupLabel", "suggestions"], outputs: ["completeMethod", "onSelect", "onUnselect", "onFocus", "onBlur", "onDropdownClick", "onClear", "onKeyUp", "onShow", "onHide"] }, { type: i5$1.Calendar, selector: "p-calendar", inputs: ["style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "numberOfMonths", "view", "touchUI", "timeSeparator", "focusTrap", "firstDayOfWeek", "showTransitionOptions", "hideTransitionOptions", "tabindex", "defaultDate", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "locale"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { type: i6$1.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "step", "inputStyle", "inputStyleClass", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown"] }, { type: i7$1.FileUpload, selector: "p-fileUpload", inputs: ["name", "url", "method", "multiple", "accept", "disabled", "auto", "withCredentials", "maxFileSize", "invalidFileSizeMessageSummary", "invalidFileSizeMessageDetail", "invalidFileTypeMessageSummary", "invalidFileTypeMessageDetail", "invalidFileLimitMessageDetail", "invalidFileLimitMessageSummary", "style", "styleClass", "previewWidth", "chooseLabel", "uploadLabel", "cancelLabel", "chooseIcon", "uploadIcon", "cancelIcon", "showUploadButton", "showCancelButton", "mode", "headers", "customUpload", "fileLimit", "files"], outputs: ["onBeforeUpload", "onSend", "onUpload", "onError", "onClear", "onRemove", "onSelect", "onProgress", "uploadHandler"] }, { type: i8.InputSwitch, selector: "p-inputSwitch", inputs: ["style", "styleClass", "tabindex", "inputId", "name", "disabled", "readonly", "ariaLabelledBy"], outputs: ["onChange"] }], directives: [{ type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i10$1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i11.InputText, selector: "[pInputText]" }, { type: i10$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i10$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i12.InputTextarea, selector: "[pInputTextarea]", inputs: ["autoResize"], outputs: ["onResize"] }, { type: i9.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i10$1.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { type: i2$1.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
477
477
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ControlComponent, decorators: [{
|
|
478
478
|
type: Component,
|
|
479
479
|
args: [{
|
|
@@ -745,10 +745,11 @@ class RegistroChildComponent {
|
|
|
745
745
|
var _a;
|
|
746
746
|
this.controls.push([]);
|
|
747
747
|
this.values.push([]);
|
|
748
|
-
(_a = layout.elements) === null || _a === void 0 ? void 0 : _a.forEach((element) => {
|
|
748
|
+
(_a = layout.elements) === null || _a === void 0 ? void 0 : _a.forEach((element, j) => {
|
|
749
749
|
if (!element.scope)
|
|
750
750
|
console.log("CONFIGURAR BIEN " + element);
|
|
751
751
|
this.controls[i].push(this.getControl(element.scope));
|
|
752
|
+
this.controls[i][j].scope = element.scope;
|
|
752
753
|
this.values[i].push(this.getValue(element.scope));
|
|
753
754
|
});
|
|
754
755
|
});
|
|
@@ -764,9 +765,14 @@ class RegistroChildComponent {
|
|
|
764
765
|
switch (typeof (value)) {
|
|
765
766
|
case 'object':
|
|
766
767
|
if (Array.isArray(value))
|
|
767
|
-
value.forEach((val) =>
|
|
768
|
-
|
|
768
|
+
value.forEach((val) => {
|
|
769
|
+
this.setValueByScope(val.scope, val.value);
|
|
770
|
+
jsonpath.value(this.data, val.scope.replace('.properties', ''), val.value);
|
|
771
|
+
});
|
|
772
|
+
else {
|
|
773
|
+
this.values[i][j] = value;
|
|
769
774
|
jsonpath.value(this.data, scope.replace('.properties', ''), value);
|
|
775
|
+
}
|
|
770
776
|
break;
|
|
771
777
|
default:
|
|
772
778
|
this.values[i][j] = value;
|
|
@@ -994,11 +1000,25 @@ class RegistroChildComponent {
|
|
|
994
1000
|
});
|
|
995
1001
|
this.applyValuesOnEvent('onChange', this.esquema, element.scope.replace('$..properties.', ''));
|
|
996
1002
|
}
|
|
1003
|
+
setValueByScope(scope, newVal) {
|
|
1004
|
+
for (let i = 0; i < this.controls.length; i++) {
|
|
1005
|
+
const row = this.controls[i];
|
|
1006
|
+
row.forEach((el, j) => {
|
|
1007
|
+
if (el.scope && el.scope.replace('.properties', '') == scope.replace('.properties', '')) {
|
|
1008
|
+
this.values[i][j] = newVal;
|
|
1009
|
+
}
|
|
1010
|
+
});
|
|
1011
|
+
}
|
|
1012
|
+
}
|
|
997
1013
|
applyValuesFromObject(event) {
|
|
998
|
-
if (event.
|
|
999
|
-
|
|
1000
|
-
|
|
1001
|
-
|
|
1014
|
+
if (event.optionValue) {
|
|
1015
|
+
for (let i = 0; i < event.optionValue.length; i++) {
|
|
1016
|
+
const optionVal = event.optionValue[i];
|
|
1017
|
+
const newVal = event.data ? this.aplyFormatValue(optionVal.scope, event.data[optionVal.key]) : null;
|
|
1018
|
+
jsonpath.value(this.data, optionVal.scope.replace('.properties', ''), this.aplyFormatValue(optionVal.scope, event.data[optionVal.key]));
|
|
1019
|
+
this.setValueByScope(optionVal.scope, newVal);
|
|
1020
|
+
}
|
|
1021
|
+
}
|
|
1002
1022
|
}
|
|
1003
1023
|
aplyFormatValue(scope, value) {
|
|
1004
1024
|
let control = jsonpath.query(this.esquema, scope)[0];
|
|
@@ -1107,10 +1127,9 @@ class RegistroComponent {
|
|
|
1107
1127
|
var _a;
|
|
1108
1128
|
this.controls.push([]);
|
|
1109
1129
|
this.values.push([]);
|
|
1110
|
-
(_a = layout.elements) === null || _a === void 0 ? void 0 : _a.forEach((element) => {
|
|
1111
|
-
if (!element.scope)
|
|
1112
|
-
console.log("CONFIGURAR BIEN " + element);
|
|
1130
|
+
(_a = layout.elements) === null || _a === void 0 ? void 0 : _a.forEach((element, j) => {
|
|
1113
1131
|
this.controls[i].push(this.getControl(element.scope));
|
|
1132
|
+
this.controls[i][j].scope = element.scope;
|
|
1114
1133
|
this.values[i].push(this.getValue(element.scope));
|
|
1115
1134
|
});
|
|
1116
1135
|
});
|
|
@@ -1169,9 +1188,14 @@ class RegistroComponent {
|
|
|
1169
1188
|
switch (typeof (value)) {
|
|
1170
1189
|
case 'object':
|
|
1171
1190
|
if (Array.isArray(value))
|
|
1172
|
-
value.forEach((val) =>
|
|
1173
|
-
|
|
1191
|
+
value.forEach((val) => {
|
|
1192
|
+
this.setValueByScope(val.scope, val.value);
|
|
1193
|
+
jsonpath.value(this.data, val.scope.replace('.properties', ''), val.value);
|
|
1194
|
+
});
|
|
1195
|
+
else {
|
|
1196
|
+
this.values[i][j] = value;
|
|
1174
1197
|
jsonpath.value(this.data, scope.replace('.properties', ''), value);
|
|
1198
|
+
}
|
|
1175
1199
|
break;
|
|
1176
1200
|
default:
|
|
1177
1201
|
this.values[i][j] = value;
|
|
@@ -1325,7 +1349,7 @@ class RegistroComponent {
|
|
|
1325
1349
|
header: element.label ? element.label : 'Detalle',
|
|
1326
1350
|
width: '70%',
|
|
1327
1351
|
modal: true,
|
|
1328
|
-
closable:
|
|
1352
|
+
closable: true,
|
|
1329
1353
|
data: {
|
|
1330
1354
|
uiEsquema: Object.assign({}, element.elements),
|
|
1331
1355
|
esquema: this.getControl(element.scope),
|
|
@@ -1343,7 +1367,7 @@ class RegistroComponent {
|
|
|
1343
1367
|
header: element.label ? element.label : 'Detalle',
|
|
1344
1368
|
width: '70%',
|
|
1345
1369
|
modal: true,
|
|
1346
|
-
closable:
|
|
1370
|
+
closable: true,
|
|
1347
1371
|
data: {
|
|
1348
1372
|
uiEsquema: Object.assign({}, element.elements),
|
|
1349
1373
|
esquema: this.getControl(element.scope),
|
|
@@ -1432,10 +1456,24 @@ class RegistroComponent {
|
|
|
1432
1456
|
});
|
|
1433
1457
|
}
|
|
1434
1458
|
applyValuesFromObject(event) {
|
|
1435
|
-
if (event.
|
|
1436
|
-
|
|
1437
|
-
|
|
1438
|
-
|
|
1459
|
+
if (event.optionValue) {
|
|
1460
|
+
for (let i = 0; i < event.optionValue.length; i++) {
|
|
1461
|
+
const optionVal = event.optionValue[i];
|
|
1462
|
+
const newVal = event.data ? this.aplyFormatValue(optionVal.scope, event.data[optionVal.key]) : null;
|
|
1463
|
+
jsonpath.value(this.data, optionVal.scope.replace('.properties', ''), this.aplyFormatValue(optionVal.scope, event.data[optionVal.key]));
|
|
1464
|
+
this.setValueByScope(optionVal.scope, newVal);
|
|
1465
|
+
}
|
|
1466
|
+
}
|
|
1467
|
+
}
|
|
1468
|
+
setValueByScope(scope, newVal) {
|
|
1469
|
+
for (let i = 0; i < this.controls.length; i++) {
|
|
1470
|
+
const row = this.controls[i];
|
|
1471
|
+
row.forEach((el, j) => {
|
|
1472
|
+
if (el.scope && el.scope.replace('.properties', '') == scope.replace('.properties', '')) {
|
|
1473
|
+
this.values[i][j] = newVal;
|
|
1474
|
+
}
|
|
1475
|
+
});
|
|
1476
|
+
}
|
|
1439
1477
|
}
|
|
1440
1478
|
aplyFormatValue(scope, value) {
|
|
1441
1479
|
let control = jsonpath.query(this.crudConfig.esquema, scope)[0];
|