sf-crud 12.0.5 → 12.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/sf-crud.umd.js +2563 -1306
- package/bundles/sf-crud.umd.js.map +1 -1
- package/esm2015/lib/components/control/control.component.js +285 -73
- package/esm2015/lib/components/file-upload/file-upload.component.js +143 -0
- package/esm2015/lib/components/form/form.component.js +267 -0
- package/esm2015/lib/components/registro/registro.component.js +507 -407
- package/esm2015/lib/components/step/step.component.js +79 -0
- package/esm2015/lib/components/tablero/tablero.component.js +87 -27
- package/esm2015/lib/sf-crud.module.js +27 -15
- package/esm2015/lib/sf-crud.routing.module.js +23 -0
- package/esm2015/lib/sf-crud.service.js +486 -12
- package/esm2015/lib/shared/models/Conditions.model.js +81 -0
- package/esm2015/lib/shared/models/Empresa.model.js +2 -0
- package/esm2015/lib/shared/models/Reason.model.js +7 -0
- package/esm2015/lib/shared/models/crud-config.model.js +36 -13
- package/esm2015/lib/shared/models/shema.model.js +5 -1
- package/esm2015/lib/shared/services/general.service.js +41 -17
- package/esm2015/lib/shared/services/notification.service.js +83 -0
- package/esm2015/lib/shared/services/step.service.js +65 -0
- package/esm2015/public-api.js +7 -1
- package/fesm2015/sf-crud.js +2194 -1151
- package/fesm2015/sf-crud.js.map +1 -1
- package/lib/components/control/control.component.d.ts +39 -10
- package/lib/components/file-upload/file-upload.component.d.ts +34 -0
- package/lib/components/form/form.component.d.ts +58 -0
- package/lib/components/registro/registro.component.d.ts +81 -54
- package/lib/components/step/step.component.d.ts +27 -0
- package/lib/components/tablero/tablero.component.d.ts +15 -5
- package/lib/sf-crud.module.d.ts +80 -76
- package/lib/sf-crud.routing.module.d.ts +7 -0
- package/lib/sf-crud.service.d.ts +115 -5
- package/lib/shared/models/Conditions.model.d.ts +32 -0
- package/lib/shared/models/Empresa.model.d.ts +11 -0
- package/lib/shared/models/Reason.model.d.ts +5 -0
- package/lib/shared/models/crud-config.model.d.ts +76 -24
- package/lib/shared/models/shema.model.d.ts +27 -0
- package/lib/shared/services/general.service.d.ts +8 -1
- package/lib/shared/services/notification.service.d.ts +27 -0
- package/lib/shared/services/step.service.d.ts +27 -0
- package/package.json +9 -2
- package/public-api.d.ts +6 -0
- package/esm2015/lib/components/registro-child/registro-child.component.js +0 -348
- package/esm2015/lib/components/registro-detalle/registro-detalle.component.js +0 -232
- package/esm2015/lib/shared/models/data-temp-crud.model.js +0 -6
- package/lib/components/registro-child/registro-child.component.d.ts +0 -48
- package/lib/components/registro-detalle/registro-detalle.component.d.ts +0 -36
- package/lib/shared/models/data-temp-crud.model.d.ts +0 -4
|
@@ -1,47 +1,175 @@
|
|
|
1
|
-
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
1
|
+
import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy, ViewChildren } from '@angular/core';
|
|
2
2
|
import { Shema } from '../../shared/models/shema.model';
|
|
3
|
+
import { RequestChecking } from '../../shared/models/crud-config.model';
|
|
4
|
+
import { Tooltip } from 'primeng/tooltip';
|
|
3
5
|
import * as moment from 'moment';
|
|
6
|
+
import * as jsonpath from 'jsonpath';
|
|
4
7
|
import * as i0 from "@angular/core";
|
|
5
8
|
import * as i1 from "../../shared/services/general.service";
|
|
6
|
-
import * as i2 from "
|
|
7
|
-
import * as i3 from "
|
|
8
|
-
import * as i4 from "primeng/
|
|
9
|
-
import * as i5 from "primeng/
|
|
10
|
-
import * as i6 from "primeng/
|
|
11
|
-
import * as i7 from "
|
|
12
|
-
import * as i8 from "primeng/
|
|
13
|
-
import * as i9 from "
|
|
14
|
-
import * as i10 from "
|
|
15
|
-
import * as i11 from "primeng/
|
|
16
|
-
import * as i12 from "
|
|
17
|
-
import * as i13 from "primeng/
|
|
18
|
-
import * as i14 from "
|
|
9
|
+
import * as i2 from "../../sf-crud.service";
|
|
10
|
+
import * as i3 from "../../shared/services/notification.service";
|
|
11
|
+
import * as i4 from "primeng/inputmask";
|
|
12
|
+
import * as i5 from "primeng/dropdown";
|
|
13
|
+
import * as i6 from "primeng/autocomplete";
|
|
14
|
+
import * as i7 from "../file-upload/file-upload.component";
|
|
15
|
+
import * as i8 from "primeng/calendar";
|
|
16
|
+
import * as i9 from "primeng/inputnumber";
|
|
17
|
+
import * as i10 from "primeng/multiselect";
|
|
18
|
+
import * as i11 from "primeng/inputswitch";
|
|
19
|
+
import * as i12 from "@angular/common";
|
|
20
|
+
import * as i13 from "primeng/tooltip";
|
|
21
|
+
import * as i14 from "@angular/forms";
|
|
22
|
+
import * as i15 from "primeng/inputtext";
|
|
23
|
+
import * as i16 from "primeng/inputtextarea";
|
|
24
|
+
import * as i17 from "primeng/button";
|
|
19
25
|
export class ControlComponent {
|
|
20
|
-
constructor(generalService) {
|
|
26
|
+
constructor(generalService, crudService, cdr, notificationService) {
|
|
21
27
|
this.generalService = generalService;
|
|
28
|
+
this.crudService = crudService;
|
|
29
|
+
this.cdr = cdr;
|
|
30
|
+
this.notificationService = notificationService;
|
|
31
|
+
this.showTempValue = false;
|
|
22
32
|
this.control = new Shema();
|
|
23
33
|
this.label = '';
|
|
24
34
|
this.setValue = new EventEmitter();
|
|
25
|
-
this.sendNotification = new EventEmitter();
|
|
26
35
|
this.sendObject = new EventEmitter();
|
|
27
36
|
this.isLoading = false;
|
|
28
37
|
this.dataFromService = [];
|
|
29
38
|
this.uploadedFiles = [];
|
|
30
39
|
this.displayAdd = false;
|
|
31
|
-
this.
|
|
40
|
+
this.uploadingFiles = false;
|
|
41
|
+
}
|
|
42
|
+
ngOnChanges(changes) {
|
|
32
43
|
}
|
|
33
44
|
ngOnInit() {
|
|
34
|
-
var _a;
|
|
35
|
-
|
|
45
|
+
var _a, _b;
|
|
46
|
+
this.loadDefaultValues();
|
|
47
|
+
if ((_b = (_a = this.control) === null || _a === void 0 ? void 0 : _a.config) === null || _b === void 0 ? void 0 : _b.depends) {
|
|
48
|
+
this.crudService.changeData$.subscribe(res => {
|
|
49
|
+
var _a, _b;
|
|
50
|
+
if (res) {
|
|
51
|
+
let registro = this.crudService.getRegistro(this.crudService.index);
|
|
52
|
+
let keyFound = (_a = registro.keys) === null || _a === void 0 ? void 0 : _a.find(k => k.scope === res.scope
|
|
53
|
+
&& this.control.config.depends.includes(k.key) &&
|
|
54
|
+
(res.index === k.indexData || res.index === k.indexAnswer));
|
|
55
|
+
if (keyFound === null || keyFound === void 0 ? void 0 : keyFound.overrideControl) {
|
|
56
|
+
let override = keyFound.overrideControl;
|
|
57
|
+
let completed = this.crudService.isConditionsCompleted((_b = override.conditions) !== null && _b !== void 0 ? _b : [], registro.conditions || [], this.crudService.getData(this.crudService.index));
|
|
58
|
+
jsonpath.value(this.control, override.property, completed ? override.value : override.elseValue);
|
|
59
|
+
this.value = this.getNewValue(override, completed);
|
|
60
|
+
this.tempValue = null;
|
|
61
|
+
this.sendValue();
|
|
62
|
+
if (this.control.subtype == 'dropdown' || this.control.subtype == 'multiselect')
|
|
63
|
+
this.loadDataFromService();
|
|
64
|
+
//this.cdr.detectChanges()
|
|
65
|
+
}
|
|
66
|
+
else if (keyFound) {
|
|
67
|
+
this.value = null;
|
|
68
|
+
this.sendValue();
|
|
69
|
+
this.loadDefaultValues();
|
|
70
|
+
//this.cdr.detectChanges()
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
getNewValue(override, completed) {
|
|
77
|
+
const newValue = completed ? override.newPropertyValue : override.elseNewPropertyValue;
|
|
78
|
+
if (newValue && typeof (newValue) == "string") {
|
|
79
|
+
if (!newValue.startsWith('$') && !newValue.startsWith('@')) {
|
|
80
|
+
return newValue;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
return null;
|
|
84
|
+
}
|
|
85
|
+
loadDefaultValues() {
|
|
86
|
+
var _a, _b, _c, _d, _e;
|
|
87
|
+
if (((_a = this.control) === null || _a === void 0 ? void 0 : _a.config) && this.control.subtype == 'dropdown' || this.control.subtype == 'multiselect')
|
|
36
88
|
this.loadDataFromService();
|
|
37
|
-
if (
|
|
38
|
-
this.
|
|
89
|
+
if (((_b = this.control) === null || _b === void 0 ? void 0 : _b.subtype) == 'autocomplete')
|
|
90
|
+
this.extracValueFromControlBusqueda();
|
|
39
91
|
if (this.value && this.control.type == 'date')
|
|
40
|
-
this.
|
|
92
|
+
this.instanceDate();
|
|
93
|
+
if (((_c = this.control) === null || _c === void 0 ? void 0 : _c.subtype) == "file") {
|
|
94
|
+
this.loadFiles();
|
|
95
|
+
}
|
|
96
|
+
if (((_d = this.control) === null || _d === void 0 ? void 0 : _d.type) == 'string')
|
|
97
|
+
this.lenghtWord = this.value ? this.value.length : 0;
|
|
98
|
+
if (((_e = this.control) === null || _e === void 0 ? void 0 : _e.subtype) == 'switch')
|
|
99
|
+
this.instanceBoolField();
|
|
100
|
+
}
|
|
101
|
+
instanceBoolField() {
|
|
102
|
+
this.tempValue = this.value;
|
|
103
|
+
if (this.value == true && this.control.trueValue !== undefined) {
|
|
104
|
+
this.value = this.control.trueValue;
|
|
105
|
+
this.sendValue();
|
|
106
|
+
}
|
|
107
|
+
else if (this.value == false && this.control.falseValue !== undefined) {
|
|
108
|
+
this.value = this.control.falseValue;
|
|
109
|
+
this.sendValue();
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
onChangeSwitch() {
|
|
113
|
+
this.value = this.tempValue;
|
|
114
|
+
this.sendValue();
|
|
115
|
+
}
|
|
116
|
+
loadFiles() {
|
|
117
|
+
this.isLoading = true;
|
|
118
|
+
this.uploadedFiles = [];
|
|
119
|
+
if (!this.value) {
|
|
120
|
+
this.isLoading = false;
|
|
121
|
+
this.cdr.detectChanges();
|
|
122
|
+
}
|
|
123
|
+
else if (this.control.config.namePattern && this.control.type == "string") {
|
|
124
|
+
let urls = this.control.config.separator ? this.value.split(",") : [this.value];
|
|
125
|
+
urls.forEach(url => this.uploadedFiles.push({ url: url, name: this.getNameFile(this.control.config.namePattern, url) }));
|
|
126
|
+
this.isLoading = false;
|
|
127
|
+
this.cdr.detectChanges();
|
|
128
|
+
}
|
|
129
|
+
else if (this.control.config.namePattern && this.control.type == "array") {
|
|
130
|
+
this.value.forEach((url) => this.uploadedFiles.push({ url: url, name: this.getNameFile(this.control.config.namePattern, url) }));
|
|
131
|
+
this.isLoading = false;
|
|
132
|
+
this.cdr.detectChanges();
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
onDeleteFile(index) {
|
|
136
|
+
var _a, _b;
|
|
137
|
+
if ((!((_a = this.control.config) === null || _a === void 0 ? void 0 : _a.limit) || ((_b = this.control.config) === null || _b === void 0 ? void 0 : _b.limit) == 1) && this.control.type == "string")
|
|
138
|
+
this.value = null;
|
|
139
|
+
else if (this.control.type == "array")
|
|
140
|
+
this.value.splice(index, 1);
|
|
141
|
+
}
|
|
142
|
+
getNameFile(namePattern, url) {
|
|
143
|
+
const regexObj = new RegExp(namePattern);
|
|
144
|
+
const match = regexObj.exec(url);
|
|
145
|
+
if (!match)
|
|
146
|
+
throw new Error("El pattern no coincide con la url. " + url);
|
|
147
|
+
return match[0];
|
|
41
148
|
}
|
|
42
149
|
sendValue() {
|
|
150
|
+
var _a;
|
|
151
|
+
if (this.control.type == "string" && this.value == "" && ((_a = this.control.config) === null || _a === void 0 ? void 0 : _a.allowEmpty) == false)
|
|
152
|
+
this.value = null;
|
|
43
153
|
this.setValue.emit(this.value);
|
|
44
154
|
}
|
|
155
|
+
sendNumberValue($event) {
|
|
156
|
+
this.value = $event.value;
|
|
157
|
+
this.sendValue();
|
|
158
|
+
}
|
|
159
|
+
onInputEmail(force) {
|
|
160
|
+
const aux = Math.abs(this.lenghtWord - this.value.length);
|
|
161
|
+
this.lenghtWord = this.value.length;
|
|
162
|
+
if (aux > 1 || force) {
|
|
163
|
+
const regex = new RegExp(/([\w\.\-_]+)?\w+@[\w-_]+(\.\w+){1,}/igm);
|
|
164
|
+
if (regex.test(this.value))
|
|
165
|
+
this.sendValue();
|
|
166
|
+
else {
|
|
167
|
+
this.value = null;
|
|
168
|
+
this.sendValue();
|
|
169
|
+
this.notificationService.addNotification({ severity: 'warn', detail: 'El correo no es válido' }, this.primeChecking());
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
}
|
|
45
173
|
sendValueFromObject(event) {
|
|
46
174
|
switch (typeof (this.control.config.optionValue)) {
|
|
47
175
|
case 'object':
|
|
@@ -53,59 +181,86 @@ export class ControlComponent {
|
|
|
53
181
|
break;
|
|
54
182
|
}
|
|
55
183
|
}
|
|
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
|
-
}
|
|
71
|
-
}
|
|
72
184
|
loadDataFromService() {
|
|
73
185
|
this.isLoading = true;
|
|
74
186
|
this.dataFromService = [];
|
|
75
|
-
|
|
187
|
+
const op = this.control.config;
|
|
188
|
+
const url = this.crudService.getURL(op, undefined, undefined);
|
|
189
|
+
this.generalService.genericRequest(this.control.config.method, url)
|
|
76
190
|
.then((res) => {
|
|
77
191
|
this.dataFromService = res.data;
|
|
192
|
+
}).finally(() => {
|
|
78
193
|
this.isLoading = false;
|
|
194
|
+
this.cdr.detectChanges();
|
|
79
195
|
});
|
|
80
196
|
}
|
|
81
197
|
loadDataFromControlBusquedaService(event) {
|
|
82
198
|
this.isLoading = true;
|
|
83
|
-
|
|
199
|
+
const op = this.control.config;
|
|
200
|
+
let url = this.crudService.getURL(op);
|
|
201
|
+
url = url.replace('@query', (event === null || event === void 0 ? void 0 : event.query) || '');
|
|
202
|
+
this.generalService.genericRequest(this.control.config.method, url)
|
|
84
203
|
.then((res) => {
|
|
204
|
+
var _a;
|
|
85
205
|
this.dataFromService = res.data;
|
|
206
|
+
if (((_a = this.dataFromService) === null || _a === void 0 ? void 0 : _a.length) == 0 && this.control.allowCustomOption) {
|
|
207
|
+
//agregar un campo que el usuario haya digitado
|
|
208
|
+
let newItem = {};
|
|
209
|
+
newItem[this.control.field] = this.tempValue;
|
|
210
|
+
newItem[this.control.config.optionValue] = this.tempValue;
|
|
211
|
+
this.dataFromService.push(newItem);
|
|
212
|
+
}
|
|
213
|
+
}).finally(() => {
|
|
86
214
|
this.isLoading = false;
|
|
215
|
+
this.cdr.detectChanges();
|
|
216
|
+
});
|
|
217
|
+
}
|
|
218
|
+
extracValueFromControlBusqueda() {
|
|
219
|
+
const op = this.control.config;
|
|
220
|
+
let url = this.crudService.getURL(op);
|
|
221
|
+
url = url.replace('@query', this.value);
|
|
222
|
+
this.generalService.genericRequest(this.control.config.method, url)
|
|
223
|
+
.then((res) => {
|
|
224
|
+
var _a;
|
|
225
|
+
if (((_a = res.data) === null || _a === void 0 ? void 0 : _a.length) == 1 && res.data[0][this.control.field]) {
|
|
226
|
+
this.tempValue = res.data[0];
|
|
227
|
+
this.value = res.data[0][this.control.field];
|
|
228
|
+
}
|
|
229
|
+
else
|
|
230
|
+
this.setDefaultValue();
|
|
231
|
+
}).finally(() => {
|
|
232
|
+
this.cdr.detectChanges();
|
|
233
|
+
}).catch(() => {
|
|
234
|
+
this.setDefaultValue();
|
|
87
235
|
});
|
|
88
236
|
}
|
|
89
237
|
onUpload(event) {
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
formData.append('uploadFile', file);
|
|
238
|
+
this.uploadingFiles = true;
|
|
239
|
+
const formData = new FormData();
|
|
240
|
+
const path = this.control.config.path || 'Imagenes/CRUD/temp';
|
|
94
241
|
formData.append('Ruta', `/${path}`);
|
|
95
|
-
|
|
96
|
-
|
|
242
|
+
for (let i = 0; i < event.length; i++)
|
|
243
|
+
formData.append(`uploadFile_${i}`, event[i]);
|
|
244
|
+
const op = this.control.config;
|
|
245
|
+
const url = this.crudService.getURL(op);
|
|
246
|
+
this.generalService.genericRequest(this.control.config.method, url, formData)
|
|
97
247
|
.then(() => {
|
|
98
|
-
|
|
99
|
-
this.
|
|
100
|
-
|
|
101
|
-
this.
|
|
248
|
+
var _a;
|
|
249
|
+
let separator = ((_a = this.control.config) === null || _a === void 0 ? void 0 : _a.separator) || ",";
|
|
250
|
+
//se asume que viene namePattern
|
|
251
|
+
if (this.control.type == "string")
|
|
252
|
+
this.value = event.map(f => `${this.generalService.jsonConfig.Server}${path}/${f.name}`).join(separator);
|
|
253
|
+
else if (this.control.type == "array")
|
|
254
|
+
this.value = event.map(f => `${this.generalService.jsonConfig.Server}${path}/${f.name}`);
|
|
255
|
+
// SI NO TRAE namePattern, debe retornar un objeto con el nombre y href
|
|
256
|
+
//else if (this.control.config.namePattern && this.control.type == "array") this.value = event.map(x => x.name)
|
|
257
|
+
//else if (!this.control.config.namePattern && this.control.type == "array") this.value = event.map(f => `${this.generalService.jsonConfig.Server}${path}/${f.name}`)
|
|
102
258
|
this.sendValue();
|
|
259
|
+
let msg = !this.control.config.limit || this.control.config.limit == 1 ? "Archivo cargado correctamente!" : "Archivos cargados correctamente!";
|
|
260
|
+
this.notificationService.addNotification({ severity: 'info', detail: msg }, this.primeChecking());
|
|
103
261
|
})
|
|
104
|
-
.catch(
|
|
105
|
-
|
|
106
|
-
this.isLoading = false;
|
|
107
|
-
this.sendNotification.emit({ severity: 'error', detail: `Error al cargar el archivo!` });
|
|
108
|
-
});
|
|
262
|
+
.catch(() => this.notificationService.addNotification({ severity: 'error', detail: `Error al cargar el archivo!` }, this.primeChecking()))
|
|
263
|
+
.finally(() => this.uploadingFiles = false);
|
|
109
264
|
}
|
|
110
265
|
refresData() {
|
|
111
266
|
var _a, _b;
|
|
@@ -113,44 +268,100 @@ export class ControlComponent {
|
|
|
113
268
|
this.loadDataFromService();
|
|
114
269
|
}
|
|
115
270
|
setDefaultValue() {
|
|
116
|
-
|
|
117
|
-
|
|
271
|
+
this.tempValue = {};
|
|
272
|
+
if (!this.control.config.optionLabel)
|
|
273
|
+
console.error("No esta bien configurado el control ", this.control);
|
|
274
|
+
else
|
|
275
|
+
this.tempValue[this.control.config.optionLabel] = this.value ? this.value : "";
|
|
118
276
|
}
|
|
119
277
|
searchValue(value) {
|
|
120
|
-
|
|
121
|
-
this.
|
|
278
|
+
const op = this.control.config;
|
|
279
|
+
let url = this.crudService.getURL(op, undefined, undefined);
|
|
280
|
+
url = url.replace('@id', value);
|
|
281
|
+
this.generalService.genericRequest(this.control.config.method, url)
|
|
122
282
|
.then((res) => {
|
|
123
283
|
var _a;
|
|
124
284
|
if (((_a = res === null || res === void 0 ? void 0 : res.data) === null || _a === void 0 ? void 0 : _a.length) > 0) {
|
|
125
285
|
this.sendObject.emit({ data: res.data[0], optionValue: this.control.config.optionValue });
|
|
126
286
|
}
|
|
127
287
|
else {
|
|
128
|
-
this.
|
|
288
|
+
this.notificationService.addNotification({ severity: 'warn', detail: `Valor no encontrado.` }, this.primeChecking());
|
|
129
289
|
this.sendObject.emit({ data: null, optionValue: this.control.config.optionValue });
|
|
130
290
|
}
|
|
131
291
|
})
|
|
132
292
|
.catch(err => {
|
|
133
|
-
|
|
134
|
-
this.sendNotification.emit({ severity: 'error', detail: `Error al consumir el servicio.` });
|
|
293
|
+
this.notificationService.addNotification({ severity: 'error', detail: `Error al consumir el servicio.` }, this.primeChecking());
|
|
135
294
|
});
|
|
136
295
|
}
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
296
|
+
primeChecking() {
|
|
297
|
+
return new RequestChecking(undefined, undefined, false, undefined, undefined, false, undefined);
|
|
298
|
+
}
|
|
299
|
+
instanceDate() {
|
|
300
|
+
const format = this.control.formatMoment;
|
|
301
|
+
if (this.value) {
|
|
302
|
+
if (typeof (this.value) == "string" && this.value.includes("T"))
|
|
303
|
+
this.value = new Date(this.value);
|
|
304
|
+
else if (typeof (this.value) == "string")
|
|
305
|
+
this.value = moment(this.value, format).toDate();
|
|
306
|
+
this.tempValue = moment(this.value).format("DD/MM/YYYY");
|
|
307
|
+
}
|
|
308
|
+
else {
|
|
309
|
+
this.tempValue = null;
|
|
310
|
+
this.value = null;
|
|
311
|
+
}
|
|
312
|
+
}
|
|
313
|
+
/**
|
|
314
|
+
* Cast tempValue to date
|
|
315
|
+
*/
|
|
316
|
+
onChangeSDate() {
|
|
317
|
+
const aux = moment(this.tempValue, "DD/MM/YYYY");
|
|
318
|
+
if (aux.isValid()) {
|
|
319
|
+
this.value = aux.toDate();
|
|
141
320
|
this.sendValue();
|
|
142
321
|
}
|
|
322
|
+
else {
|
|
323
|
+
this.tempValue = null;
|
|
324
|
+
this.notificationService.addNotification({ severity: 'warn', detail: 'La fecha no es válida' }, this.primeChecking());
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
onChangeDate() {
|
|
328
|
+
this.tempValue = moment(this.value).format("DD/MM/YYYY");
|
|
329
|
+
this.sendValue();
|
|
330
|
+
}
|
|
331
|
+
onTouchDescription() {
|
|
332
|
+
var _a;
|
|
333
|
+
try {
|
|
334
|
+
(_a = this.tooltips.get(0)) === null || _a === void 0 ? void 0 : _a.activate();
|
|
335
|
+
}
|
|
336
|
+
catch (ex) { }
|
|
337
|
+
}
|
|
338
|
+
onUnTouchDescription() {
|
|
339
|
+
var _a;
|
|
340
|
+
try {
|
|
341
|
+
(_a = this.tooltips.get(0)) === null || _a === void 0 ? void 0 : _a.deactivate();
|
|
342
|
+
}
|
|
343
|
+
catch (ex) { }
|
|
344
|
+
}
|
|
345
|
+
doFocusOut() {
|
|
346
|
+
if (document.activeElement) {
|
|
347
|
+
document.activeElement.blur();
|
|
348
|
+
}
|
|
349
|
+
this.cdr.detectChanges();
|
|
143
350
|
}
|
|
144
351
|
}
|
|
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 });
|
|
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)\" [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.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"] }] });
|
|
352
|
+
ControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ControlComponent, deps: [{ token: i1.GeneralService }, { token: i2.SfCrudService }, { token: i0.ChangeDetectorRef }, { token: i3.NotificationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
353
|
+
ControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: ControlComponent, selector: "sf-control", inputs: { showTempValue: "showTempValue", control: "control", label: "label", value: "value", appendTo: "appendTo" }, outputs: { setValue: "setValue", sendObject: "sendObject" }, viewQueries: [{ propertyName: "tooltips", predicate: Tooltip, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<p *ngIf=\"showTempValue && tempValue\">{{tempValue[control.field]}}</p>\r\n\r\n<div *ngIf=\"!showTempValue\" [ngSwitch]=\"control.type\" #cc class=\"control-container\">\r\n <div class=\"label-container\">\r\n <label [for]=\"label\">{{label}}</label>\r\n <i #tooltip *ngIf=\"control.tooltip\" class=\"pi pi-question-circle\"\r\n [tooltipPosition]=\"control.tooltipPosition || 'top'\" [pTooltip]=\"control.tooltip\"\r\n (touchstart)=\"onTouchDescription()\" (touchend)=\"onUnTouchDescription()\"></i>\r\n </div>\r\n\r\n <ng-container *ngSwitchCase=\"'string'\" >\r\n <ng-container [ngSwitch]=\"control.subtype\">\r\n <ng-container *ngSwitchCase=\"'input'\">\r\n <input pInputText [name]=\"label\" type=\"text\" [(ngModel)]=\"value\" (input)=\"sendValue()\"\r\n [disabled]=\"control.disabled || false\" [autocomplete]=\"control.autocomplete || 'off'\">\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'textarea'\">\r\n <textarea [rows]=\"control.config?.rows ? control.config.rows : 4\" [(ngModel)]=\"value\"\r\n (input)=\"sendValue()\" pInputTextarea [disabled]=\"control.config?.disabled || false\"\r\n [autoResize]=\"control.config?.autoresize || false\"></textarea>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'password'\">\r\n <input pInputText type=\"password\" [(ngModel)]=\"value\" (input)=\"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 [disabled]=\"control.disabled || false\" autocomplete=\"email\" (input)=\"onInputEmail(false)\"\r\n (focusout)=\"onInputEmail(true)\" (keyup.enter)=\"doFocusOut()\">\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 [disabled]=\"control.disabled || false\" autocomplete=\"tel-national\"\r\n [unmask]=\"control.unmask || false\" (onComplete)=\"sendValue()\"></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\" 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:replace'\">\r\n <p-dropdown [lazy]=\"isLoading\" [options]=\"dataFromService\"\r\n (onChange)=\"sendValueFromObject($event)\" [optionLabel]=\"control.config.optionLabel\"\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=\"'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 (keyup.enter)=\"doFocusOut()\" />\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 *ngSwitchCase=\"'file'\">\r\n <sf-file-upload *ngIf=\"!isLoading\" [accept]=\"control.config?.accept || 'image/*,application/pdf'\"\r\n [loading]=\"uploadingFiles\" [files]=\"uploadedFiles\" [configName]=\"control.config?.configName\"\r\n [limit]=\"control.config?.limit || 1\" (onUpload)=\"onUpload($event)\"\r\n (onDeleteFile)=\"onDeleteFile($event)\"></sf-file-upload>\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 <div class=\"p-col-12\">\r\n <div class=\"p-inputgroup\">\r\n <p-inputMask [(ngModel)]=\"tempValue\" mask=\"99/99/9999\" [placeholder]=\"control.placeholder\"\r\n (onComplete)=\"onChangeSDate()\" [disabled]=\"control.disabled || false\"></p-inputMask>\r\n <p-calendar [(ngModel)]=\"value\" class=\"only-icon\" [monthNavigator]=\"true\" [yearNavigator]=\"true\" yearRange=\"1900:2035\"\r\n [dateFormat]=\"control.format || 'yy-mm-dd'\" appendTo=\"body\" [disabled]=\"control.disabled || false\"\r\n [showOnFocus]=\"!control.hide\" [placeholder]=\"control.placeholder || 'aaaa-mm-dd'\"\r\n [touchUI]=\"control.touchUI || false\" [showIcon]=\"control.showIcon || false\" (onSelect)=\"onChangeDate()\"\r\n (onBlur)=\"onChangeDate()\"></p-calendar>\r\n </div>\r\n </div>\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\" (ngModelChange)=\"value = $event; sendValue()\" mode=\"decimal\" [minFractionDigits]=\"control.minFractionDigits || 0\"\r\n [min]=\"control.min || null\" [max]=\"control.max || null\" (onInput)=\"sendNumberValue($event)\"\r\n [prefix]=\"control.currency || '$ '\" [disabled]=\"control.disabled || false\"></p-inputNumber>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'decimal'\">\r\n <p-inputNumber [ngModel]=\"value\" mode=\"decimal\" (ngModelChange)=\"value = $event; sendValue()\" [min]=\"control.min || null\"\r\n [max]=\"control.max || null\" [minFractionDigits]=\"control.minFractionDigits || 0\"\r\n [locale]=\"control.locale || undefined\" [useGrouping]=\"control.useGrouping || false\"\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=\" %\" (ngModelChange)=\"value = $event; sendValue()\" (onInput)=\"sendValue()\" [min]=\"control.min || null\"\r\n [max]=\"control.max || null\" [minFractionDigits]=\"control.minFractionDigits || 2\"\r\n [locale]=\"control.locale || undefined\" [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 (keyup.enter)=\"doFocusOut()\" />\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=\"'array'\">\r\n <ng-container [ngSwitch]=\"control.subtype\">\r\n <ng-container *ngSwitchCase=\"'file'\">\r\n <sf-file-upload *ngIf=\"!isLoading\" [loading]=\"uploadingFiles\" [files]=\"uploadedFiles\"\r\n [configName]=\"control.config?.configName\" [limit]=\"control.config?.limit || 1\"\r\n [accept]=\"control.config?.accept || 'image/*,application/pdf'\" (onUpload)=\"onUpload($event)\"\r\n (onDeleteFile)=\"onDeleteFile($event)\"></sf-file-upload>\r\n </ng-container>\r\n <ng-container *ngSwitchCase=\"'multiselect'\">\r\n <p-multiSelect [options]=\"dataFromService\" [(ngModel)]=\"value\" (onChange)=\"sendValue()\"\r\n [optionLabel]=\"control.config?.optionLabel\" [optionValue]=\"control.config?.optionValue\"\r\n [placeholder]=\"control.config?.placeholder\"\r\n [display]=\"control.config?.display || 'chip'\"></p-multiSelect>\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)]=\"tempValue\" (onChange)=\"onChangeSwitch()\" [id]=\"label\"\r\n [trueValue]=\"control?.trueValue !== undefined ? control?.trueValue: null\"\r\n [falseValue]=\"control?.falseValue !== undefined ? control?.falseValue: null\"></p-inputSwitch>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n</div>\r\n", styles: ["::ng-deep .label-container{& label{margin-right:10px;color:#55585b;font-size:17px}& i{font-size:1.1rem}}::ng-deep .p-tooltip{max-width:15rem;font-size:.85rem;text-align:center}.control-container ::ng-deep .p-button:hover{background:var(--secondary-color)!important;border-color:var(--secondary-color)!important;filter:brightness(85%)}.control-container ::ng-deep .p-component,.control-container ::ng-deep .p-component *{border-radius:6px}.control-container ::ng-deep .p-inputtext{font-size:17px;border:1px solid #d1d5db;border-radius:6px}.control-container ::ng-deep .p-inputtext:focus,.control-container ::ng-deep .p-inputtext:active,.control-container ::ng-deep .p-inputwrapper:focus,.control-container ::ng-deep .p-inputwrapper:active{border-color:var(--button-color)}.control-container ::ng-deep .p-inputtext:enabled:focus{border-color:var(--secondary-color)!important;box-shadow:inset 0 0 0 1px #fff}.control-container ::ng-deep input.p-inputtext::placeholder{color:#6b7280;font-family:sans-serif;font-size:18px}.control-container ::ng-deep .p-dropdown{background:#ffffff;border:1px solid #d1d5db;transition:background-color .2s,color .2s,border-color .2s,box-shadow .2s;border-radius:6px}.control-container ::ng-deep .p-dropdown:not(.p-disabled):hover{border-color:var(--secondary-color)!important}.control-container ::ng-deep .p-dropdown:not(.p-disabled).p-focus{border-color:var(--secondary-color)!important;box-shadow:inset 0 0 0 1px #fff}.control-container ::ng-deep .p-dropdown .p-inputtext{border:none}.control-container ::ng-deep .p-dropdown .p-dropdown-label.p-placeholder{font-family:sans-serif;color:#6b7280}.control-container ::ng-deep .p-button.p-button-danger,.control-container ::ng-deep .p-buttonset.p-button-danger>.p-button,.control-container ::ng-deep .p-splitbutton.p-button-danger>.p-button{border-color:var(--secondary-color)!important;background:var(--secondary-color)!important}.control-container ::ng-deep .p-inputgroup button:last-child{border-top-right-radius:6px;border-bottom-right-radius:6px}.control-container ::ng-deep .p-inputgroup input:last-child{border-top-right-radius:0;border-bottom-right-radius:0}.control-container ::ng-deep .p-inputgroup input:first-child{border-top-left-radius:6px;border-bottom-left-radius:6px}.control-container ::ng-deep .p-datepicker-touch-ui .p-datepicker-title{padding:3px}.control-container ::ng-deep .p-datepicker-month,.control-container ::ng-deep .p-datepicker-month:focus,.control-container ::ng-deep .p-datepicker-year:focus,.control-container ::ng-deep .p-datepicker-year{border:none}.p-inputgroup{& p-calendar{display:contents;& input{display:none}& .p-button-icon-only{border-top-left-radius:0;border-bottom-left-radius:0}}& p-inputMask{display:contents;& ::ng-deep input{border-top-right-radius:0;border-bottom-right-radius:0}}}@media (max-width <=768px){:host{font-size:14px}}\n"], components: [{ type: i4.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: i5.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: i6.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: i7.FileUploadComponent, selector: "sf-file-upload", inputs: ["limit", "files", "loading", "configName", "accept"], outputs: ["onUpload", "onDeleteFile"] }, { type: i8.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: i9.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: i10.MultiSelect, selector: "p-multiSelect", inputs: ["style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "autoZIndex", "baseZIndex", "filterBy", "virtualScroll", "itemSize", "showTransitionOptions", "hideTransitionOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "scrollHeight", "defaultLabel", "placeholder", "options", "filterValue"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onPanelShow", "onPanelHide"] }, { type: i11.InputSwitch, selector: "p-inputSwitch", inputs: ["style", "styleClass", "tabindex", "inputId", "name", "disabled", "readonly", "ariaLabelledBy"], outputs: ["onChange"] }], directives: [{ type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i12.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i13.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { type: i12.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i14.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: i15.InputText, selector: "[pInputText]" }, { type: i14.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i14.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i16.InputTextarea, selector: "[pInputTextarea]", inputs: ["autoResize"], outputs: ["onResize"] }, { type: i17.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { type: i14.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
147
354
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ControlComponent, decorators: [{
|
|
148
355
|
type: Component,
|
|
149
356
|
args: [{
|
|
150
357
|
selector: 'sf-control',
|
|
151
|
-
templateUrl: './control.component.html'
|
|
358
|
+
templateUrl: './control.component.html',
|
|
359
|
+
styleUrls: ['./control.component.css'],
|
|
360
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
152
361
|
}]
|
|
153
|
-
}], ctorParameters: function () { return [{ type: i1.GeneralService }]; }, propDecorators: {
|
|
362
|
+
}], ctorParameters: function () { return [{ type: i1.GeneralService }, { type: i2.SfCrudService }, { type: i0.ChangeDetectorRef }, { type: i3.NotificationService }]; }, propDecorators: { showTempValue: [{
|
|
363
|
+
type: Input
|
|
364
|
+
}], control: [{
|
|
154
365
|
type: Input
|
|
155
366
|
}], label: [{
|
|
156
367
|
type: Input
|
|
@@ -160,9 +371,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
160
371
|
type: Input
|
|
161
372
|
}], setValue: [{
|
|
162
373
|
type: Output
|
|
163
|
-
}], sendNotification: [{
|
|
164
|
-
type: Output
|
|
165
374
|
}], sendObject: [{
|
|
166
375
|
type: Output
|
|
376
|
+
}], tooltips: [{
|
|
377
|
+
type: ViewChildren,
|
|
378
|
+
args: [Tooltip]
|
|
167
379
|
}] } });
|
|
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)\" [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)\" [(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>"]}
|
|
380
|
+
//# 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, ChangeDetectionStrategy, ChangeDetectorRef, ViewChildren, QueryList, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { GeneralService } from '../../shared/services/general.service';\r\nimport { Shema } from '../../shared/models/shema.model';\r\nimport { Operation, OverrideConfig, RequestChecking } from '../../shared/models/crud-config.model';\r\nimport { SfCrudService } from '../../sf-crud.service';\r\nimport { Tooltip } from 'primeng/tooltip';\r\nimport * as moment from 'moment';\r\nimport { Archivo } from '../file-upload/file-upload.component';\r\nimport { NotificationService } from '../../shared/services/notification.service';\r\nimport * as jsonpath from 'jsonpath';\r\n\r\n@Component({\r\n  selector: 'sf-control',\r\n  templateUrl: './control.component.html',\r\n  styleUrls: ['./control.component.css'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class ControlComponent implements OnInit, OnChanges {\r\n\r\n  @Input() showTempValue:Boolean = false;\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() sendObject: EventEmitter<any> = new EventEmitter<any>();\r\n  @ViewChildren(Tooltip) tooltips!: QueryList <Tooltip>;\r\n\r\n  private lenghtWord!: number;\r\n  public isLoading: boolean = false;\r\n  public dataFromService: any[] = [];\r\n  public uploadedFiles: Archivo[] = [];\r\n  public displayAdd: boolean = false;\r\n  public tempValue: any;\r\n\r\n  public uploadingFiles = false;\r\n\r\n\r\n  constructor(\r\n    private generalService: GeneralService,\r\n    private crudService: SfCrudService,\r\n    private cdr: ChangeDetectorRef,\r\n    private notificationService: NotificationService\r\n  ) { }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.loadDefaultValues()\r\n    if (this.control?.config?.depends){\r\n      this.crudService.changeData$.subscribe(res => {\r\n        if (res){\r\n          let registro = this.crudService.getRegistro(this.crudService.index)\r\n          let keyFound = registro.keys?.find(k => k.scope === res.scope\r\n          &&  (this.control.config.depends as string[]).includes(k.key) &&\r\n          (res.index === k.indexData || res.index === k.indexAnswer))\r\n          if (keyFound?.overrideControl){\r\n            let override = keyFound.overrideControl\r\n            let completed = this.crudService.isConditionsCompleted(override.conditions ?? [], registro.conditions || [], this.crudService.getData(this.crudService.index))\r\n            jsonpath.value(this.control, override.property, completed ? override.value : override.elseValue)\r\n            this.value = this.getNewValue(override, completed);\r\n            this.tempValue = null\r\n            this.sendValue()\r\n            if (this.control.subtype == 'dropdown' || this.control.subtype == 'multiselect') this.loadDataFromService()\r\n            //this.cdr.detectChanges()\r\n          }\r\n          else if (keyFound) {\r\n            this.value = null\r\n            this.sendValue()\r\n            this.loadDefaultValues()\r\n            //this.cdr.detectChanges()\r\n          }\r\n\r\n        }\r\n      })\r\n    }\r\n  }\r\n\r\n  private getNewValue(override: OverrideConfig, completed: boolean): any {\r\n    const newValue = completed ? override.newPropertyValue: override.elseNewPropertyValue;\r\n    if (newValue && typeof(newValue) == \"string\"){\r\n      if (!newValue.startsWith('$') && !newValue.startsWith('@')){\r\n        return newValue;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  loadDefaultValues(){\r\n    if (this.control?.config && this.control.subtype == 'dropdown' || this.control.subtype == 'multiselect') this.loadDataFromService();\r\n    if (this.control?.subtype == 'autocomplete') this.extracValueFromControlBusqueda();\r\n    if (this.value && this.control.type == 'date') this.instanceDate();\r\n    if (this.control?.subtype == \"file\") {\r\n      this.loadFiles();\r\n    }\r\n    if (this.control?.type == 'string') this.lenghtWord = this.value ? this.value.length : 0\r\n    if (this.control?.subtype == 'switch') this.instanceBoolField()\r\n  }\r\n  instanceBoolField() {\r\n    this.tempValue = this.value\r\n    if (this.value == true && this.control.trueValue !== undefined) {\r\n      this.value = this.control.trueValue\r\n      this.sendValue()\r\n    }\r\n    else if (this.value == false && this.control.falseValue !== undefined) {\r\n      this.value = this.control.falseValue\r\n      this.sendValue()\r\n    }\r\n  }\r\n\r\n  onChangeSwitch(){\r\n    this.value = this.tempValue\r\n    this.sendValue()\r\n  }\r\n\r\n  loadFiles(){\r\n    this.isLoading = true\r\n    this.uploadedFiles = []\r\n    if (!this.value) {\r\n      this.isLoading = false\r\n      this.cdr.detectChanges()\r\n    }\r\n    else if (this.control.config.namePattern && this.control.type == \"string\") {\r\n      let urls: string[] = this.control.config.separator ? this.value.split(\",\") : [this.value]\r\n      urls.forEach(url => this.uploadedFiles.push({url:url,  name:this.getNameFile(this.control.config.namePattern, url)}))\r\n      this.isLoading = false\r\n      this.cdr.detectChanges()\r\n    }\r\n    else if (this.control.config.namePattern && this.control.type == \"array\") {\r\n      this.value.forEach((url:string) => this.uploadedFiles.push({url:url,  name:this.getNameFile(this.control.config.namePattern, url)}))\r\n      this.isLoading = false\r\n      this.cdr.detectChanges()\r\n    }\r\n  }\r\n\r\n  onDeleteFile(index: number){\r\n    if ((!this.control.config?.limit || this.control.config?.limit == 1) && this.control.type == \"string\") this.value = null\r\n    else if (this.control.type == \"array\") this.value.splice(index, 1)\r\n  }\r\n\r\n  getNameFile(namePattern: string, url: string): string {\r\n    const regexObj = new RegExp(namePattern);\r\n    const match = regexObj.exec(url);\r\n    if (!match) throw new Error(\"El pattern no coincide con la url. \" + url);\r\n    return match[0];\r\n  }\r\n\r\n  sendValue() {\r\n    if (this.control.type == \"string\" && this.value == \"\" && this.control.config?.allowEmpty == false) this.value = null\r\n    this.setValue.emit(this.value);\r\n  }\r\n\r\n  sendNumberValue($event: any){\r\n    this.value = $event.value\r\n    this.sendValue()\r\n  }\r\n\r\n  onInputEmail(force:boolean){\r\n    const aux = Math.abs(this.lenghtWord - this.value.length)\r\n    this.lenghtWord = this.value.length\r\n    if (aux > 1 || force){\r\n        const 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.notificationService.addNotification({ severity: 'warn', detail: 'El correo no es válido' }, this.primeChecking());\r\n        }\r\n    }\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  loadDataFromService() {\r\n    this.isLoading = true;\r\n    this.dataFromService = [];\r\n    const op: Operation = this.control.config\r\n    const url = this.crudService.getURL(op, undefined, undefined)\r\n    this.generalService.genericRequest(this.control.config.method, url)\r\n      .then((res: any) => {\r\n        this.dataFromService = res.data;\r\n      }).finally(() => {\r\n          this.isLoading = false\r\n          this.cdr.detectChanges()\r\n      })\r\n  }\r\n\r\n  loadDataFromControlBusquedaService(event: any) {\r\n    this.isLoading = true;\r\n    const op: Operation = this.control.config\r\n    let url = this.crudService.getURL(op)\r\n    url = url.replace('@query', event?.query || '')\r\n    this.generalService.genericRequest(this.control.config.method, url)\r\n      .then((res: any) => {\r\n        this.dataFromService = res.data;\r\n        if (this.dataFromService?.length == 0 && this.control.allowCustomOption) {\r\n          //agregar un campo que el usuario haya digitado\r\n          let newItem: any = {}\r\n          newItem[this.control.field] = this.tempValue\r\n          newItem[this.control.config.optionValue] = this.tempValue\r\n          this.dataFromService.push(newItem)\r\n        }\r\n      }).finally(() => {\r\n          this.isLoading = false\r\n          this.cdr.detectChanges()\r\n      })\r\n  }\r\n\r\n  extracValueFromControlBusqueda(){\r\n    const op: Operation = this.control.config\r\n    let url = this.crudService.getURL(op)\r\n    url = url.replace('@query', this.value)\r\n    this.generalService.genericRequest(this.control.config.method, url)\r\n      .then((res: any) => {\r\n        if (res.data?.length == 1 && res.data[0][this.control.field]){\r\n          this.tempValue = res.data[0]\r\n          this.value = res.data[0][this.control.field]\r\n        }\r\n        else this.setDefaultValue()\r\n      }).finally(() => {\r\n        this.cdr.detectChanges()\r\n    }).catch(() => {\r\n      this.setDefaultValue()\r\n    })\r\n  }\r\n\r\n\r\n  onUpload(event: File[]) {\r\n    this.uploadingFiles = true\r\n    const formData = new FormData();\r\n    const path = this.control.config.path || 'Imagenes/CRUD/temp';\r\n    formData.append('Ruta', `/${path}`);\r\n\r\n    for (let i = 0; i < event.length; i++) formData.append(`uploadFile_${i}`, event[i]);\r\n    const op: Operation = this.control.config\r\n    const url = this.crudService.getURL(op)\r\n    this.generalService.genericRequest(this.control.config.method, url, formData)\r\n    .then(() => {\r\n      let separator = this.control.config?.separator || \",\"\r\n      //se asume que viene namePattern\r\n      if (this.control.type == \"string\") this.value = event.map(f => `${this.generalService.jsonConfig.Server}${path}/${f.name}`).join(separator)\r\n      else if (this.control.type == \"array\") this.value = event.map(f => `${this.generalService.jsonConfig.Server}${path}/${f.name}`)\r\n      // SI NO TRAE namePattern, debe retornar un objeto con el nombre y href\r\n      //else if (this.control.config.namePattern && this.control.type == \"array\") this.value = event.map(x => x.name)\r\n      //else if (!this.control.config.namePattern && this.control.type == \"array\") this.value = event.map(f => `${this.generalService.jsonConfig.Server}${path}/${f.name}`)\r\n      this.sendValue()\r\n      let msg = !this.control.config.limit || this.control.config.limit == 1 ? \"Archivo cargado correctamente!\": \"Archivos cargados correctamente!\"\r\n      this.notificationService.addNotification({ severity: 'info', detail: msg }, this.primeChecking())\r\n    })\r\n    .catch(() => this.notificationService.addNotification({ severity: 'error', detail: `Error al cargar el archivo!` }, this.primeChecking()))\r\n    .finally(() => this.uploadingFiles = false)\r\n\r\n  }\r\n\r\n  refresData() {\r\n    if (this.control?.config?.endpointtemp) this.loadDataFromService();\r\n  }\r\n  setDefaultValue(){\r\n    this.tempValue = {}\r\n    if (!this.control.config.optionLabel) console.error(\"No esta bien configurado el control \", this.control)\r\n    else this.tempValue[this.control.config.optionLabel] = this.value ? this.value: \"\"\r\n\r\n  }\r\n\r\n  searchValue(value: string){\r\n    const op: Operation = this.control.config\r\n    let url = this.crudService.getURL(op, undefined, undefined)\r\n    url = url.replace('@id', value)\r\n\r\n\r\n    this.generalService.genericRequest(this.control.config.method, url)\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.notificationService.addNotification({severity: 'warn', detail:`Valor no encontrado.`}, this.primeChecking())\r\n          this.sendObject.emit({ data: null, optionValue: this.control.config.optionValue } )\r\n        }\r\n      })\r\n      .catch(err=> {\r\n        this.notificationService.addNotification({severity: 'error', detail:`Error al consumir el servicio.`},this.primeChecking())\r\n      })\r\n  }\r\n\r\n  primeChecking(){\r\n    return new RequestChecking(undefined, undefined, false, undefined, undefined, false, undefined)\r\n  }\r\n\r\n  instanceDate(){\r\n    const format = (this.control as any).formatMoment\r\n\r\n    if (this.value){\r\n      if (typeof(this.value) == \"string\" && (this.value as string).includes(\"T\")) this.value = new Date(this.value)\r\n      else if (typeof(this.value) == \"string\") this.value = moment(this.value, format).toDate();\r\n      this.tempValue = moment(this.value).format(\"DD/MM/YYYY\")\r\n    }else {\r\n      this.tempValue = null\r\n      this.value = null\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Cast tempValue to date\r\n   */\r\n  onChangeSDate(){\r\n    const aux = moment(this.tempValue, \"DD/MM/YYYY\")\r\n    if (aux.isValid()){\r\n      this.value = aux.toDate();\r\n      this.sendValue()\r\n    }\r\n    else {\r\n      this.tempValue = null;\r\n      this.notificationService.addNotification({ severity: 'warn', detail: 'La fecha no es válida' }, this.primeChecking())\r\n    }\r\n  }\r\n\r\n\r\n  onChangeDate(){\r\n    this.tempValue = moment(this.value).format(\"DD/MM/YYYY\")\r\n    this.sendValue()\r\n  }\r\n\r\n    onTouchDescription() {\r\n      try{\r\n        this.tooltips.get(0)?.activate()\r\n      }catch(ex){}\r\n\r\n  }\r\n\r\n  onUnTouchDescription() {\r\n      try{\r\n        this.tooltips.get(0)?.deactivate()\r\n      }catch(ex){}\r\n}\r\n\r\n  doFocusOut(){\r\n    if (document.activeElement) {\r\n        (document.activeElement as HTMLElement).blur();\r\n    }\r\n    this.cdr.detectChanges()\r\n  }\r\n\r\n}\r\n","<p *ngIf=\"showTempValue && tempValue\">{{tempValue[control.field]}}</p>\r\n\r\n<div *ngIf=\"!showTempValue\" [ngSwitch]=\"control.type\" #cc class=\"control-container\">\r\n    <div class=\"label-container\">\r\n        <label [for]=\"label\">{{label}}</label>\r\n        <i #tooltip *ngIf=\"control.tooltip\" class=\"pi pi-question-circle\"\r\n            [tooltipPosition]=\"control.tooltipPosition || 'top'\" [pTooltip]=\"control.tooltip\"\r\n            (touchstart)=\"onTouchDescription()\" (touchend)=\"onUnTouchDescription()\"></i>\r\n    </div>\r\n\r\n    <ng-container *ngSwitchCase=\"'string'\" >\r\n        <ng-container [ngSwitch]=\"control.subtype\">\r\n            <ng-container *ngSwitchCase=\"'input'\">\r\n                <input pInputText [name]=\"label\" type=\"text\" [(ngModel)]=\"value\" (input)=\"sendValue()\"\r\n                    [disabled]=\"control.disabled || false\" [autocomplete]=\"control.autocomplete || 'off'\">\r\n            </ng-container>\r\n            <ng-container *ngSwitchCase=\"'textarea'\">\r\n                <textarea [rows]=\"control.config?.rows ? control.config.rows : 4\" [(ngModel)]=\"value\"\r\n                    (input)=\"sendValue()\" pInputTextarea [disabled]=\"control.config?.disabled || false\"\r\n                    [autoResize]=\"control.config?.autoresize || false\"></textarea>\r\n          </ng-container>\r\n            <ng-container *ngSwitchCase=\"'password'\">\r\n                <input pInputText type=\"password\" [(ngModel)]=\"value\" (input)=\"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                    [disabled]=\"control.disabled || false\" autocomplete=\"email\" (input)=\"onInputEmail(false)\"\r\n                    (focusout)=\"onInputEmail(true)\" (keyup.enter)=\"doFocusOut()\">\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                    [disabled]=\"control.disabled || false\" autocomplete=\"tel-national\"\r\n                    [unmask]=\"control.unmask || false\" (onComplete)=\"sendValue()\"></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\" 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:replace'\">\r\n                <p-dropdown [lazy]=\"isLoading\" [options]=\"dataFromService\"\r\n                    (onChange)=\"sendValueFromObject($event)\" [optionLabel]=\"control.config.optionLabel\"\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=\"'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                        (keyup.enter)=\"doFocusOut()\" />\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 *ngSwitchCase=\"'file'\">\r\n                <sf-file-upload *ngIf=\"!isLoading\" [accept]=\"control.config?.accept || 'image/*,application/pdf'\"\r\n                    [loading]=\"uploadingFiles\" [files]=\"uploadedFiles\" [configName]=\"control.config?.configName\"\r\n                    [limit]=\"control.config?.limit || 1\" (onUpload)=\"onUpload($event)\"\r\n                    (onDeleteFile)=\"onDeleteFile($event)\"></sf-file-upload>\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                <div class=\"p-col-12\">\r\n                    <div class=\"p-inputgroup\">\r\n                        <p-inputMask [(ngModel)]=\"tempValue\" mask=\"99/99/9999\" [placeholder]=\"control.placeholder\"\r\n                            (onComplete)=\"onChangeSDate()\" [disabled]=\"control.disabled || false\"></p-inputMask>\r\n                        <p-calendar [(ngModel)]=\"value\" class=\"only-icon\" [monthNavigator]=\"true\" [yearNavigator]=\"true\" yearRange=\"1900:2035\"\r\n                            [dateFormat]=\"control.format || 'yy-mm-dd'\" appendTo=\"body\" [disabled]=\"control.disabled || false\"\r\n                            [showOnFocus]=\"!control.hide\" [placeholder]=\"control.placeholder || 'aaaa-mm-dd'\"\r\n                            [touchUI]=\"control.touchUI || false\" [showIcon]=\"control.showIcon || false\" (onSelect)=\"onChangeDate()\"\r\n                            (onBlur)=\"onChangeDate()\"></p-calendar>\r\n                    </div>\r\n                </div>\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\"  (ngModelChange)=\"value = $event; sendValue()\" mode=\"decimal\" [minFractionDigits]=\"control.minFractionDigits || 0\"\r\n                    [min]=\"control.min || null\" [max]=\"control.max || null\" (onInput)=\"sendNumberValue($event)\"\r\n                    [prefix]=\"control.currency || '$ '\" [disabled]=\"control.disabled || false\"></p-inputNumber>\r\n            </ng-container>\r\n            <ng-container *ngSwitchCase=\"'decimal'\">\r\n                <p-inputNumber [ngModel]=\"value\" mode=\"decimal\" (ngModelChange)=\"value = $event; sendValue()\" [min]=\"control.min || null\"\r\n                    [max]=\"control.max || null\" [minFractionDigits]=\"control.minFractionDigits || 0\"\r\n                    [locale]=\"control.locale || undefined\" [useGrouping]=\"control.useGrouping || false\"\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=\" %\" (ngModelChange)=\"value = $event; sendValue()\" (onInput)=\"sendValue()\" [min]=\"control.min || null\"\r\n                    [max]=\"control.max || null\" [minFractionDigits]=\"control.minFractionDigits || 2\"\r\n                    [locale]=\"control.locale || undefined\" [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                        (keyup.enter)=\"doFocusOut()\" />\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=\"'array'\">\r\n        <ng-container [ngSwitch]=\"control.subtype\">\r\n            <ng-container *ngSwitchCase=\"'file'\">\r\n                <sf-file-upload *ngIf=\"!isLoading\" [loading]=\"uploadingFiles\" [files]=\"uploadedFiles\"\r\n                    [configName]=\"control.config?.configName\" [limit]=\"control.config?.limit || 1\"\r\n                    [accept]=\"control.config?.accept || 'image/*,application/pdf'\" (onUpload)=\"onUpload($event)\"\r\n                    (onDeleteFile)=\"onDeleteFile($event)\"></sf-file-upload>\r\n            </ng-container>\r\n            <ng-container *ngSwitchCase=\"'multiselect'\">\r\n                <p-multiSelect [options]=\"dataFromService\" [(ngModel)]=\"value\" (onChange)=\"sendValue()\"\r\n                    [optionLabel]=\"control.config?.optionLabel\" [optionValue]=\"control.config?.optionValue\"\r\n                    [placeholder]=\"control.config?.placeholder\"\r\n                    [display]=\"control.config?.display || 'chip'\"></p-multiSelect>\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)]=\"tempValue\" (onChange)=\"onChangeSwitch()\" [id]=\"label\"\r\n                [trueValue]=\"control?.trueValue !== undefined ? control?.trueValue: null\"\r\n                [falseValue]=\"control?.falseValue !== undefined ? control?.falseValue: null\"></p-inputSwitch>\r\n            </ng-container>\r\n        </ng-container>\r\n    </ng-container>\r\n</div>\r\n"]}
|