sf-crud 12.0.1-beta9 → 12.0.3
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 +1225 -125
- package/bundles/sf-crud.umd.js.map +1 -1
- package/esm2015/lib/components/control/control.component.js +114 -12
- package/esm2015/lib/components/registro/registro.component.js +309 -43
- package/esm2015/lib/components/registro-child/registro-child.component.js +330 -0
- package/esm2015/lib/components/registro-detalle/registro-detalle.component.js +232 -0
- package/esm2015/lib/components/tablero/tablero.component.js +81 -19
- package/esm2015/lib/sf-crud.module.js +24 -13
- package/esm2015/lib/sf-crud.service.js +16 -2
- package/esm2015/lib/shared/models/crud-config.model.js +51 -0
- package/esm2015/lib/shared/models/data-temp-crud.model.js +6 -0
- package/esm2015/lib/shared/models/shema.model.js +7 -0
- package/esm2015/lib/shared/services/general.service.js +1 -1
- package/esm2015/public-api.js +2 -1
- package/fesm2015/sf-crud.js +1078 -91
- package/fesm2015/sf-crud.js.map +1 -1
- package/lib/components/control/control.component.d.ts +16 -3
- package/lib/components/registro/registro.component.d.ts +45 -10
- package/lib/components/registro-child/registro-child.component.d.ts +47 -0
- package/lib/components/registro-detalle/registro-detalle.component.d.ts +36 -0
- package/lib/components/tablero/tablero.component.d.ts +17 -4
- package/lib/sf-crud.module.d.ts +76 -74
- package/lib/sf-crud.service.d.ts +4 -0
- package/lib/shared/{services/models → models}/crud-config.model.d.ts +18 -2
- package/lib/shared/models/data-temp-crud.model.d.ts +4 -0
- package/lib/shared/{services/models → models}/shema.model.d.ts +1 -0
- package/lib/shared/services/general.service.d.ts +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/esm2015/lib/shared/services/models/crud-config.model.js +0 -43
- package/esm2015/lib/shared/services/models/shema.model.js +0 -7
|
@@ -1,36 +1,77 @@
|
|
|
1
1
|
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
|
-
import { Shema } from '../../shared/
|
|
2
|
+
import { Shema } from '../../shared/models/shema.model';
|
|
3
|
+
import * as moment from 'moment';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "../../shared/services/general.service";
|
|
5
|
-
import * as i2 from "primeng/
|
|
6
|
-
import * as i3 from "primeng/
|
|
7
|
-
import * as i4 from "primeng/
|
|
8
|
-
import * as i5 from "primeng/
|
|
9
|
-
import * as i6 from "
|
|
10
|
-
import * as i7 from "
|
|
11
|
-
import * as i8 from "primeng/
|
|
6
|
+
import * as i2 from "primeng/inputmask";
|
|
7
|
+
import * as i3 from "primeng/dropdown";
|
|
8
|
+
import * as i4 from "primeng/autocomplete";
|
|
9
|
+
import * as i5 from "primeng/calendar";
|
|
10
|
+
import * as i6 from "primeng/inputnumber";
|
|
11
|
+
import * as i7 from "primeng/fileupload";
|
|
12
|
+
import * as i8 from "primeng/inputswitch";
|
|
13
|
+
import * as i9 from "@angular/common";
|
|
14
|
+
import * as i10 from "@angular/forms";
|
|
15
|
+
import * as i11 from "primeng/inputtext";
|
|
16
|
+
import * as i12 from "primeng/inputtextarea";
|
|
17
|
+
import * as i13 from "primeng/button";
|
|
18
|
+
import * as i14 from "primeng/api";
|
|
12
19
|
export class ControlComponent {
|
|
13
20
|
constructor(generalService) {
|
|
14
21
|
this.generalService = generalService;
|
|
15
22
|
this.control = new Shema();
|
|
16
23
|
this.label = '';
|
|
17
24
|
this.setValue = new EventEmitter();
|
|
25
|
+
this.sendNotification = new EventEmitter();
|
|
26
|
+
this.sendObject = new EventEmitter();
|
|
18
27
|
this.isLoading = false;
|
|
19
28
|
this.dataFromService = [];
|
|
29
|
+
this.uploadedFiles = [];
|
|
30
|
+
this.displayAdd = false;
|
|
31
|
+
this.tempValue = {};
|
|
20
32
|
}
|
|
21
33
|
ngOnInit() {
|
|
22
34
|
var _a;
|
|
23
35
|
if (((_a = this.control) === null || _a === void 0 ? void 0 : _a.config) && this.control.subtype == 'dropdown')
|
|
24
36
|
this.loadDataFromService();
|
|
37
|
+
if (this.value && this.control.subtype == 'autocomplete')
|
|
38
|
+
this.setDefaultValue();
|
|
39
|
+
if (this.value && this.control.type == 'date')
|
|
40
|
+
this.setDate();
|
|
25
41
|
}
|
|
26
42
|
sendValue() {
|
|
27
43
|
this.setValue.emit(this.value);
|
|
28
44
|
}
|
|
29
|
-
sendValueFromObject() {
|
|
30
|
-
|
|
45
|
+
sendValueFromObject(event) {
|
|
46
|
+
switch (typeof (this.control.config.optionValue)) {
|
|
47
|
+
case 'object':
|
|
48
|
+
this.control.config.optionValue.forEach((op) => op['value'] = event[op.key]);
|
|
49
|
+
this.setValue.emit(this.control.config.optionValue);
|
|
50
|
+
break;
|
|
51
|
+
default:
|
|
52
|
+
this.setValue.emit(event[this.control.config.optionValue]);
|
|
53
|
+
break;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
validateValue(type) {
|
|
57
|
+
switch (type) {
|
|
58
|
+
case 'email':
|
|
59
|
+
let regex = new RegExp(/([\w\.\-_]+)?\w+@[\w-_]+(\.\w+){1,}/igm);
|
|
60
|
+
if (regex.test(this.value))
|
|
61
|
+
this.sendValue();
|
|
62
|
+
else {
|
|
63
|
+
this.value = null;
|
|
64
|
+
this.sendValue();
|
|
65
|
+
this.sendNotification.emit({ severity: 'warn', detail: 'El correo no es válido' });
|
|
66
|
+
}
|
|
67
|
+
break;
|
|
68
|
+
default:
|
|
69
|
+
break;
|
|
70
|
+
}
|
|
31
71
|
}
|
|
32
72
|
loadDataFromService() {
|
|
33
73
|
this.isLoading = true;
|
|
74
|
+
this.dataFromService = [];
|
|
34
75
|
this.generalService.genericRequest(this.control.config.method, this.control.config.server, this.control.config.endpoint)
|
|
35
76
|
.then((res) => {
|
|
36
77
|
this.dataFromService = res.data;
|
|
@@ -45,9 +86,64 @@ export class ControlComponent {
|
|
|
45
86
|
this.isLoading = false;
|
|
46
87
|
});
|
|
47
88
|
}
|
|
89
|
+
onUpload(event) {
|
|
90
|
+
let file = event.files[0];
|
|
91
|
+
let formData = new FormData();
|
|
92
|
+
let path = 'Imagenes/CRUD/temp';
|
|
93
|
+
formData.append('uploadFile', file);
|
|
94
|
+
formData.append('Ruta', `/${path}`);
|
|
95
|
+
this.isLoading = true;
|
|
96
|
+
this.generalService.genericRequest(this.control.config.method, this.control.config.server, this.control.config.endpoint, formData)
|
|
97
|
+
.then(() => {
|
|
98
|
+
this.sendNotification.emit({ severity: 'info', detail: `Archivo cargado correctamente!` });
|
|
99
|
+
this.uploadedFiles.push(file);
|
|
100
|
+
this.isLoading = false;
|
|
101
|
+
this.value = `${this.generalService.jsonConfig.Server}${path}/${file.name}`;
|
|
102
|
+
this.sendValue();
|
|
103
|
+
})
|
|
104
|
+
.catch(err => {
|
|
105
|
+
console.log(err);
|
|
106
|
+
this.isLoading = false;
|
|
107
|
+
this.sendNotification.emit({ severity: 'error', detail: `Error al cargar el archivo!` });
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
refresData() {
|
|
111
|
+
var _a, _b;
|
|
112
|
+
if ((_b = (_a = this.control) === null || _a === void 0 ? void 0 : _a.config) === null || _b === void 0 ? void 0 : _b.endpointtemp)
|
|
113
|
+
this.loadDataFromService();
|
|
114
|
+
}
|
|
115
|
+
setDefaultValue() {
|
|
116
|
+
var _a;
|
|
117
|
+
Object.defineProperty(this.tempValue, (_a = this.control.config) === null || _a === void 0 ? void 0 : _a.optionLabel, { value: this.value, writable: true, enumerable: true, configurable: true });
|
|
118
|
+
}
|
|
119
|
+
searchValue(value) {
|
|
120
|
+
let endpoint = this.control.config.endpoint.replace('@id', value);
|
|
121
|
+
this.generalService.genericRequest(this.control.config.method, this.control.config.server, endpoint)
|
|
122
|
+
.then((res) => {
|
|
123
|
+
var _a;
|
|
124
|
+
if (((_a = res === null || res === void 0 ? void 0 : res.data) === null || _a === void 0 ? void 0 : _a.length) > 0) {
|
|
125
|
+
this.sendObject.emit({ data: res.data[0], optionValue: this.control.config.optionValue });
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
this.sendNotification.emit({ severity: 'warn', detail: `Valor no encontrado.` });
|
|
129
|
+
this.sendObject.emit({ data: null, optionValue: this.control.config.optionValue });
|
|
130
|
+
}
|
|
131
|
+
})
|
|
132
|
+
.catch(err => {
|
|
133
|
+
console.log(err);
|
|
134
|
+
this.sendNotification.emit({ severity: 'error', detail: `Error al consumir el servicio.` });
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
setDate() {
|
|
138
|
+
let format = this.control.formatMoment;
|
|
139
|
+
if (format && this.value && !(this.value instanceof Date)) {
|
|
140
|
+
this.value = moment(this.value, format).toDate();
|
|
141
|
+
this.sendValue();
|
|
142
|
+
}
|
|
143
|
+
}
|
|
48
144
|
}
|
|
49
145
|
ControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ControlComponent, deps: [{ token: i1.GeneralService }], target: i0.ɵɵFactoryTarget.Component });
|
|
50
|
-
ControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: ControlComponent, selector: "sf-control", inputs: { control: "control", label: "label", value: "value" }, outputs: { setValue: "setValue" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"control.type\">\r\n <label>{{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 </ng-container>\r\n <ng-container *ngSwitchCase=\"'password'\">\r\n <input pInputText type=\"password\" [(ngModel)]=\"value\" (focusout)=\"sendValue()\">\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'email'\">\r\n <input pInputText type=\"email\" [(ngModel)]=\"value\" (focusout)=\"sendValue()\">\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'phone'\">\r\n <input pInputText type=\"tel\" [(ngModel)]=\"value\" (focusout)=\"sendValue()\">\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'enum'\">\r\n <p-dropdown [options]=\"control.enum\" [(ngModel)]=\"value\" (onChange)=\"sendValue()\"\r\n placeholder=\"Seleccione una opci\u00F3n\"></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\" [optionValue]=\"control.config.optionValue\"\r\n placeholder=\"Seleccione una opci\u00F3n\"></p-dropdown>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'autocomplete'\">\r\n <p-autoComplete [(ngModel)]=\"value\" [showEmptyMessage]=\"true\" [suggestions]=\"dataFromService\"\r\n (completeMethod)=\"loadDataFromControlBusquedaService($event)\" [field]=\"control.field\"\r\n [minLength]=\"1\" (onSelect)=\"sendValueFromObject()\"></p-autoComplete>\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()\"\r\n [format]=\"control?.format || 'yy-mm-dd'\"></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 (onChange)=\"sendValue()\" [currency]=\"control?.currency || 'USD'\"></p-inputNumber>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'decimal'\">\r\n <p-inputNumber [(ngModel)]=\"value\" mode=\"decimal\" (onChange)=\"sendValue()\"\r\n [minFractionDigits]=\"control?.minFractionDigits || 0\"></p-inputNumber>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'percentage'\">\r\n <p-inputNumber [(ngModel)]=\"value\" suffix=\" %\" (onChange)=\"sendValue()\"\r\n [minFractionDigits]=\"control?.minFractionDigits || 2\"></p-inputNumber>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</ng-container>", components: [{ type: i2.Dropdown, selector: "p-dropdown", inputs: ["scrollHeight", "resetFilterOnHide", "dropdownIcon", "optionGroupChildren", "autoDisplayFirst", "emptyFilterMessage", "emptyMessage", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "autofocusFilter", "disabled", "options", "filterValue", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "filterPlaceholder", "filterLocale", "inputId", "selectId", "dataKey", "filterBy", "autofocus", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "group", "showClear", "virtualScroll", "itemSize", "ariaFilterLabel", "ariaLabelledBy", "maxlength", "tooltipStyleClass"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide"] }, { type: i3.AutoComplete, selector: "p-autoComplete", inputs: ["minLength", "delay", "type", "autoZIndex", "baseZIndex", "dropdownIcon", "unique", "completeOnFocus", "scrollHeight", "dropdownMode", "showTransitionOptions", "hideTransitionOptions", "autocomplete", "suggestions", "disabled", "style", "panelStyle", "styleClass", "panelStyleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "readonly", "virtualScroll", "itemSize", "maxlength", "name", "required", "size", "appendTo", "autoHighlight", "forceSelection", "ariaLabel", "ariaLabelledBy", "group", "field", "dropdown", "showEmptyMessage", "multiple", "tabindex", "dataKey", "emptyMessage", "autofocus", "optionGroupChildren", "optionGroupLabel"], outputs: ["completeMethod", "onSelect", "onUnselect", "onFocus", "onBlur", "onDropdownClick", "onClear", "onKeyUp", "onShow", "onHide"] }, { type: i4.Calendar, selector: "p-calendar", inputs: ["dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "icon", "shortYearCutoff", "hourFormat", "stepHour", "stepMinute", "stepSecond", "showSeconds", "showOnFocus", "showWeek", "dataType", "selectionMode", "todayButtonStyleClass", "clearButtonStyleClass", "autoZIndex", "baseZIndex", "keepInvalid", "hideOnDateTimeSelect", "numberOfMonths", "view", "timeSeparator", "focusTrap", "firstDayOfWeek", "showTransitionOptions", "hideTransitionOptions", "defaultDate", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "locale", "disabled", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "selectOtherMonths", "showIcon", "appendTo", "readonlyInput", "monthNavigator", "yearNavigator", "timeOnly", "required", "maxDateCount", "showButtonBar", "panelStyleClass", "panelStyle", "touchUI", "tabindex"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { type: i5.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "incrementButtonIcon", "decrementButtonIcon", "step", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "disabled", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "inputStyle", "inputStyleClass"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown"] }], directives: [{ type: i6.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i6.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i7.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: i8.InputText, selector: "[pInputText]" }, { type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
146
|
+
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.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.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.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.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.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.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: i9.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i9.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i10.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.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i10.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: i13.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i10.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { type: i14.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i9.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
51
147
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ControlComponent, decorators: [{
|
|
52
148
|
type: Component,
|
|
53
149
|
args: [{
|
|
@@ -60,7 +156,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
60
156
|
type: Input
|
|
61
157
|
}], value: [{
|
|
62
158
|
type: Input
|
|
159
|
+
}], appendTo: [{
|
|
160
|
+
type: Input
|
|
63
161
|
}], setValue: [{
|
|
64
162
|
type: Output
|
|
163
|
+
}], sendNotification: [{
|
|
164
|
+
type: Output
|
|
165
|
+
}], sendObject: [{
|
|
166
|
+
type: Output
|
|
65
167
|
}] } });
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control.component.js","sourceRoot":"","sources":["../../../../../../projects/sf-crud/src/lib/components/control/control.component.ts","../../../../../../projects/sf-crud/src/lib/components/control/control.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAE,KAAK,EAAE,MAAM,0CAA0C,CAAC;;;;;;;;;;AAMjE,MAAM,OAAO,gBAAgB;IAU3B,YACU,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;QAT/B,YAAO,GAAU,IAAI,KAAK,EAAE,CAAC;QAC7B,UAAK,GAAW,EAAE,CAAC;QAElB,aAAQ,GAAsB,IAAI,YAAY,EAAO,CAAC;QAEzD,cAAS,GAAY,KAAK,CAAC;QAC3B,oBAAe,GAAU,EAAE,CAAC;IAI/B,CAAC;IAEL,QAAQ;;QACN,IAAI,CAAA,MAAA,IAAI,CAAC,OAAO,0CAAE,MAAM,KAAI,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,UAAU;YAAE,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7F,CAAC;IAED,SAAS;QACP,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC;IAClE,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC;aACrH,IAAI,CAAC,CAAC,GAAQ,EAAE,EAAE;YACjB,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC,IAAI,CAAC;YAChC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,CAAC,CAAA;IACN,CAAC;IAED,kCAAkC,CAAC,KAAU;QAC3C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,KAAK,KAAI,EAAE,CAAC,CAAC;aAC3J,IAAI,CAAC,CAAC,GAAQ,EAAE,EAAE;YACjB,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC,IAAI,CAAC;YAChC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,CAAC,CAAA;IACN,CAAC;;8GA1CU,gBAAgB;kGAAhB,gBAAgB,qJCR7B,2/GAwDe;4FDhDF,gBAAgB;kBAJ5B,SAAS;mBAAC;oBACT,QAAQ,EAAE,YAAY;oBACtB,WAAW,EAAE,0BAA0B;iBACxC;qGAGU,OAAO;sBAAf,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACI,QAAQ;sBAAjB,MAAM","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';\r\nimport { GeneralService } from '../../shared/services/general.service';\r\nimport { Shema } from '../../shared/services/models/shema.model';\r\n\r\n@Component({\r\n  selector: 'sf-control',\r\n  templateUrl: './control.component.html'\r\n})\r\nexport class ControlComponent implements OnInit {\r\n\r\n  @Input() control: Shema = new Shema();\r\n  @Input() label: string = '';\r\n  @Input() value: any;\r\n  @Output() setValue: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  public isLoading: boolean = false;\r\n  public dataFromService: any[] = [];\r\n\r\n  constructor(\r\n    private generalService: GeneralService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    if (this.control?.config && this.control.subtype == 'dropdown') this.loadDataFromService();\r\n  }\r\n\r\n  sendValue() {\r\n    this.setValue.emit(this.value);\r\n  }\r\n  \r\n  sendValueFromObject() {\r\n    this.setValue.emit(this.value[this.control.config.optionValue]);\r\n  }\r\n\r\n  loadDataFromService() {\r\n    this.isLoading = true;\r\n    this.generalService.genericRequest(this.control.config.method, this.control.config.server, this.control.config.endpoint)\r\n      .then((res: any) => {\r\n        this.dataFromService = res.data;\r\n        this.isLoading = false;\r\n      })\r\n  }\r\n\r\n  loadDataFromControlBusquedaService(event: any) {\r\n    this.isLoading = true;\r\n    this.generalService.genericRequest(this.control.config.method, this.control.config.server, this.control.config.endpoint.replace('@query', event?.query || ''))\r\n      .then((res: any) => {\r\n        this.dataFromService = res.data;\r\n        this.isLoading = false;\r\n      })\r\n  }\r\n\r\n}\r\n","<ng-container [ngSwitch]=\"control.type\">\r\n    <label>{{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            </ng-container>\r\n            <ng-container *ngSwitchCase=\"'password'\">\r\n                <input pInputText type=\"password\" [(ngModel)]=\"value\" (focusout)=\"sendValue()\">\r\n            </ng-container>\r\n            <ng-container *ngSwitchCase=\"'email'\">\r\n                <input pInputText type=\"email\" [(ngModel)]=\"value\" (focusout)=\"sendValue()\">\r\n            </ng-container>\r\n            <ng-container *ngSwitchCase=\"'phone'\">\r\n                <input pInputText type=\"tel\" [(ngModel)]=\"value\" (focusout)=\"sendValue()\">\r\n            </ng-container>\r\n            <ng-container *ngSwitchCase=\"'enum'\">\r\n                <p-dropdown [options]=\"control.enum\" [(ngModel)]=\"value\" (onChange)=\"sendValue()\"\r\n                    placeholder=\"Seleccione una opción\"></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\" [optionValue]=\"control.config.optionValue\"\r\n                    placeholder=\"Seleccione una opción\"></p-dropdown>\r\n            </ng-container>\r\n            <ng-container *ngSwitchCase=\"'autocomplete'\">\r\n                <p-autoComplete [(ngModel)]=\"value\" [showEmptyMessage]=\"true\" [suggestions]=\"dataFromService\"\r\n                    (completeMethod)=\"loadDataFromControlBusquedaService($event)\" [field]=\"control.field\"\r\n                    [minLength]=\"1\" (onSelect)=\"sendValueFromObject()\"></p-autoComplete>\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()\"\r\n                    [format]=\"control?.format || 'yy-mm-dd'\"></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                    (onChange)=\"sendValue()\" [currency]=\"control?.currency || 'USD'\"></p-inputNumber>\r\n            </ng-container>\r\n            <ng-container *ngSwitchCase=\"'decimal'\">\r\n                <p-inputNumber [(ngModel)]=\"value\" mode=\"decimal\" (onChange)=\"sendValue()\"\r\n                    [minFractionDigits]=\"control?.minFractionDigits || 0\"></p-inputNumber>\r\n            </ng-container>\r\n            <ng-container *ngSwitchCase=\"'percentage'\">\r\n                <p-inputNumber [(ngModel)]=\"value\" suffix=\" %\" (onChange)=\"sendValue()\"\r\n                    [minFractionDigits]=\"control?.minFractionDigits || 2\"></p-inputNumber>\r\n            </ng-container>\r\n        </ng-container>\r\n    </ng-container>\r\n</ng-container>"]}
|
|
168
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control.component.js","sourceRoot":"","sources":["../../../../../../projects/sf-crud/src/lib/components/control/control.component.ts","../../../../../../projects/sf-crud/src/lib/components/control/control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';\r\nimport { GeneralService } from '../../shared/services/general.service';\r\nimport { Message } from 'primeng/api';\r\nimport { Shema } from '../../shared/models/shema.model';\r\nimport * as moment from 'moment';\r\n\r\n@Component({\r\n  selector: 'sf-control',\r\n  templateUrl: './control.component.html'\r\n})\r\nexport class ControlComponent implements OnInit {\r\n\r\n  @Input() control: Shema = new Shema();\r\n  @Input() label: string = '';\r\n  @Input() value: any;\r\n  @Input() appendTo: any;\r\n  @Output() setValue: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() sendNotification: EventEmitter<Message> = new EventEmitter<Message>();\r\n  @Output() sendObject: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  public isLoading: boolean = false;\r\n  public dataFromService: any[] = [];\r\n  public uploadedFiles: any[] = [];\r\n  public displayAdd: boolean = false;\r\n  public tempValue: any = {}\r\n\r\n  constructor(\r\n    private generalService: GeneralService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    if (this.control?.config && this.control.subtype == 'dropdown') this.loadDataFromService();\r\n    if (this.value && this.control.subtype == 'autocomplete') this.setDefaultValue();\r\n    if (this.value && this.control.type == 'date') this.setDate();\r\n  }\r\n\r\n  sendValue() {\r\n    this.setValue.emit(this.value);\r\n  }\r\n\r\n  sendValueFromObject(event: any) {\r\n    switch (typeof (this.control.config.optionValue)) {\r\n      case 'object':\r\n        this.control.config.optionValue.forEach((op: any) => op['value'] = event[op.key])\r\n        this.setValue.emit(this.control.config.optionValue);\r\n        break;\r\n      default:\r\n        this.setValue.emit(event[this.control.config.optionValue]);\r\n        break;\r\n    }\r\n  }\r\n\r\n  validateValue(type: string) {\r\n    switch (type) {\r\n      case 'email':\r\n        let regex: RegExp = new RegExp(/([\\w\\.\\-_]+)?\\w+@[\\w-_]+(\\.\\w+){1,}/igm);\r\n        if (regex.test(this.value)) this.sendValue();\r\n        else {\r\n          this.value = null;\r\n          this.sendValue()\r\n          this.sendNotification.emit({ severity: 'warn', detail: 'El correo no es válido' })\r\n        }\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n  }\r\n\r\n  loadDataFromService() {\r\n    this.isLoading = true;\r\n    this.dataFromService = [];\r\n    this.generalService.genericRequest(this.control.config.method, this.control.config.server, this.control.config.endpoint)\r\n      .then((res: any) => {\r\n        this.dataFromService = res.data;\r\n        this.isLoading = false;\r\n      })\r\n  }\r\n\r\n  loadDataFromControlBusquedaService(event: any) {\r\n    this.isLoading = true;\r\n    this.generalService.genericRequest(this.control.config.method, this.control.config.server, this.control.config.endpoint.replace('@query', event?.query || ''))\r\n      .then((res: any) => {\r\n        this.dataFromService = res.data;\r\n        this.isLoading = false;\r\n      })\r\n  }\r\n\r\n  onUpload(event: any) {\r\n    let file = event.files[0];\r\n    let formData = new FormData();\r\n    let path = 'Imagenes/CRUD/temp';\r\n    formData.append('uploadFile', file);\r\n    formData.append('Ruta', `/${path}`);\r\n    this.isLoading = true;\r\n    this.generalService.genericRequest(this.control.config.method, this.control.config.server, this.control.config.endpoint, formData)\r\n      .then(() => {\r\n        this.sendNotification.emit({ severity: 'info', detail: `Archivo cargado correctamente!` })\r\n        this.uploadedFiles.push(file);\r\n        this.isLoading = false;\r\n        this.value = `${this.generalService.jsonConfig.Server}${path}/${file.name}`\r\n        this.sendValue()\r\n      })\r\n      .catch(err => {\r\n        console.log(err)\r\n        this.isLoading = false\r\n        this.sendNotification.emit({ severity: 'error', detail: `Error al cargar el archivo!` })\r\n      })\r\n  }\r\n\r\n  refresData() {\r\n    if (this.control?.config?.endpointtemp) this.loadDataFromService();\r\n  }\r\n\r\n  setDefaultValue(){\r\n    Object.defineProperty(this.tempValue, this.control.config?.optionLabel, { value: this.value, writable: true, enumerable: true, configurable: true })\r\n  }\r\n\r\n  searchValue(value: string){\r\n    let endpoint = this.control.config.endpoint.replace('@id', value)\r\n    this.generalService.genericRequest(this.control.config.method, this.control.config.server, endpoint)\r\n      .then((res: any) => {\r\n        if (res?.data?.length > 0){\r\n          this.sendObject.emit({ data: res.data[0], optionValue: this.control.config.optionValue } )\r\n        }else{\r\n          this.sendNotification.emit({severity: 'warn', detail:`Valor no encontrado.`})\r\n          this.sendObject.emit({ data: null, optionValue: this.control.config.optionValue } )\r\n        }\r\n      })\r\n      .catch(err=> {\r\n        console.log(err)\r\n        this.sendNotification.emit({severity: 'error', detail:`Error al consumir el servicio.`})\r\n      })\r\n  }\r\n\r\n  setDate(){\r\n    let format = (this.control as any).formatMoment\r\n    \r\n    if(format && this.value && !(this.value instanceof Date)){\r\n      this.value = moment(this.value, format).toDate();\r\n      this.sendValue()\r\n\r\n    } \r\n  }\r\n}\r\n","<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ón\" [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ón\"\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ón\"\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>"]}
|