brainloper-ui 14.1.1 → 14.1.2
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/esm2020/src/app/modules/brainloper-ui/components/data-table/data-table.component.mjs +4 -4
- package/esm2020/src/app/modules/brainloper-ui/components/file-input/file-input.component.mjs +68 -67
- package/esm2020/src/app/modules/interfaces/file-forms-service/file-input-params.mjs +1 -1
- package/fesm2015/brainloper-ui.mjs +70 -69
- package/fesm2015/brainloper-ui.mjs.map +1 -1
- package/fesm2020/brainloper-ui.mjs +70 -69
- package/fesm2020/brainloper-ui.mjs.map +1 -1
- package/package.json +2 -2
- package/src/app/modules/interfaces/file-forms-service/file-input-params.d.ts +1 -1
|
@@ -1807,13 +1807,13 @@ class DataTableComponent {
|
|
|
1807
1807
|
let active = false;
|
|
1808
1808
|
const allowedExtensions = [
|
|
1809
1809
|
'.png', '.jpeg', '.jpg', '.gif', '.bmp', '.webp', '.svg',
|
|
1810
|
-
'.pdf', '.doc', '.docx', '.xls', '.xlsx'
|
|
1810
|
+
'.pdf', '.doc', '.docx', '.xls', '.xlsx', '.document'
|
|
1811
1811
|
];
|
|
1812
1812
|
rules.forEach(rule => {
|
|
1813
|
-
if (rule.action === enumActions$1.SHOW_FILE_ICON && value && value.
|
|
1813
|
+
if (rule.action === enumActions$1.SHOW_FILE_ICON && value && value.includes('/docs/')) {
|
|
1814
1814
|
const lowerValue = value.toLowerCase();
|
|
1815
1815
|
for (const ext of allowedExtensions) {
|
|
1816
|
-
if (lowerValue.
|
|
1816
|
+
if (lowerValue.includes(ext)) {
|
|
1817
1817
|
active = true;
|
|
1818
1818
|
break;
|
|
1819
1819
|
}
|
|
@@ -2215,7 +2215,7 @@ class FileInputComponent {
|
|
|
2215
2215
|
});
|
|
2216
2216
|
this.sizePicture = {
|
|
2217
2217
|
width: `${this.params.style.width}`,
|
|
2218
|
-
height: `${this.params.style.height}
|
|
2218
|
+
height: this.params.style.height ? `${this.params.style.height}` : '200px',
|
|
2219
2219
|
"border-radius": '5%',
|
|
2220
2220
|
border: `${this.params.style.border}`,
|
|
2221
2221
|
};
|
|
@@ -2225,7 +2225,17 @@ class FileInputComponent {
|
|
|
2225
2225
|
else {
|
|
2226
2226
|
this.edit = '';
|
|
2227
2227
|
}
|
|
2228
|
-
this.typeFile
|
|
2228
|
+
let types = Array.isArray(this.params.typeFile) ? this.params.typeFile : [this.params.typeFile];
|
|
2229
|
+
this.typeFile = types;
|
|
2230
|
+
this.type = types.map(t => {
|
|
2231
|
+
if (t === 'imagen')
|
|
2232
|
+
return 'image/*';
|
|
2233
|
+
if (t === 'pdf')
|
|
2234
|
+
return '.pdf';
|
|
2235
|
+
if (t === 'doc')
|
|
2236
|
+
return '.doc,.docx';
|
|
2237
|
+
return '';
|
|
2238
|
+
}).join(',');
|
|
2229
2239
|
this.functionTypeFile();
|
|
2230
2240
|
}
|
|
2231
2241
|
functionTypeFile() {
|
|
@@ -2246,77 +2256,68 @@ class FileInputComponent {
|
|
|
2246
2256
|
height: '100%',
|
|
2247
2257
|
"border-radius": `${this.sizePicture['border-radius']}`,
|
|
2248
2258
|
};
|
|
2249
|
-
|
|
2250
|
-
|
|
2251
|
-
|
|
2252
|
-
|
|
2253
|
-
|
|
2254
|
-
else {
|
|
2255
|
-
this.imageSrc = this.params.imageSrc;
|
|
2256
|
-
}
|
|
2257
|
-
this.type = 'image/*';
|
|
2258
|
-
break;
|
|
2259
|
-
case 'pdf':
|
|
2260
|
-
this.type = '.pdf';
|
|
2261
|
-
this.imageSrc = imagenFondoTransparente;
|
|
2262
|
-
break;
|
|
2263
|
-
case 'doc':
|
|
2264
|
-
this.type = '.doc, .docx';
|
|
2265
|
-
this.imageSrc = imagenFondoTransparente;
|
|
2266
|
-
break;
|
|
2267
|
-
default:
|
|
2268
|
-
break;
|
|
2259
|
+
if (this.typeFile.includes('imagen')) {
|
|
2260
|
+
this.imageSrc = this.params.imageSrc || imagenFondoTransparente;
|
|
2261
|
+
}
|
|
2262
|
+
else {
|
|
2263
|
+
this.imageSrc = imagenFondoTransparente;
|
|
2269
2264
|
}
|
|
2270
2265
|
}
|
|
2271
2266
|
fileChange($event) {
|
|
2272
2267
|
return __awaiter(this, void 0, void 0, function* () {
|
|
2273
|
-
|
|
2274
|
-
|
|
2275
|
-
|
|
2276
|
-
|
|
2277
|
-
|
|
2278
|
-
|
|
2279
|
-
|
|
2280
|
-
|
|
2281
|
-
|
|
2282
|
-
|
|
2283
|
-
|
|
2284
|
-
|
|
2285
|
-
|
|
2286
|
-
|
|
2287
|
-
|
|
2288
|
-
|
|
2289
|
-
|
|
2290
|
-
|
|
2291
|
-
|
|
2292
|
-
reader.onload = e => this.imageSrc = reader.result;
|
|
2293
|
-
reader.readAsDataURL(this.file);
|
|
2294
|
-
r = yield this.compressor();
|
|
2295
|
-
break;
|
|
2296
|
-
case 'doc':
|
|
2297
|
-
r = false;
|
|
2298
|
-
this.styleImg = {
|
|
2299
|
-
width: '100%',
|
|
2300
|
-
height: '100%',
|
|
2301
|
-
"border-radius": `${this.sizePicture['border-radius']}`,
|
|
2302
|
-
"background-image": `url(${imagenDoc})`,
|
|
2303
|
-
"background-position": "center",
|
|
2304
|
-
"background-size": "30% 65%",
|
|
2305
|
-
"background-repeat": "no-repeat"
|
|
2306
|
-
};
|
|
2307
|
-
break;
|
|
2308
|
-
default:
|
|
2309
|
-
break;
|
|
2268
|
+
const file = $event.target['files'][0];
|
|
2269
|
+
if (!file)
|
|
2270
|
+
return;
|
|
2271
|
+
if (file.size < 15000000) {
|
|
2272
|
+
this.file = file;
|
|
2273
|
+
const mime = file.type;
|
|
2274
|
+
const name = file.name.toLowerCase();
|
|
2275
|
+
// NUEVO: Detectar tipo según archivo subido y lo permitido
|
|
2276
|
+
if (mime.startsWith('image/') && this.typeFile.includes('imagen')) {
|
|
2277
|
+
// Imagen
|
|
2278
|
+
const reader = new FileReader();
|
|
2279
|
+
reader.onload = e => this.imageSrc = reader.result;
|
|
2280
|
+
reader.readAsDataURL(this.file);
|
|
2281
|
+
const r = yield this.compressor();
|
|
2282
|
+
if (r === false) {
|
|
2283
|
+
this.fileSave.emit({ new: this.file });
|
|
2284
|
+
}
|
|
2285
|
+
else {
|
|
2286
|
+
this.fileSave.emit({ new: this.file, compressor: r });
|
|
2310
2287
|
}
|
|
2311
2288
|
}
|
|
2312
|
-
if (
|
|
2289
|
+
else if ((mime === 'application/pdf' || name.endsWith('.pdf')) && this.typeFile.includes('pdf')) {
|
|
2290
|
+
// PDF
|
|
2291
|
+
this.imageSrc = '';
|
|
2292
|
+
this.styleImg = {
|
|
2293
|
+
width: '100%',
|
|
2294
|
+
height: '100%',
|
|
2295
|
+
"border-radius": `${this.sizePicture['border-radius']}`,
|
|
2296
|
+
"background-image": `url(${imagenPdf})`,
|
|
2297
|
+
"background-position": "center",
|
|
2298
|
+
"background-size": "30% 65%",
|
|
2299
|
+
"background-repeat": "no-repeat"
|
|
2300
|
+
};
|
|
2301
|
+
this.fileSave.emit({ new: this.file });
|
|
2302
|
+
}
|
|
2303
|
+
else if ((mime === 'application/msword' ||
|
|
2304
|
+
mime === 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' ||
|
|
2305
|
+
name.endsWith('.doc') || name.endsWith('.docx')) && this.typeFile.includes('doc')) {
|
|
2306
|
+
// DOC/DOCX
|
|
2307
|
+
this.imageSrc = '';
|
|
2308
|
+
this.styleImg = {
|
|
2309
|
+
width: '100%',
|
|
2310
|
+
height: '100%',
|
|
2311
|
+
"border-radius": `${this.sizePicture['border-radius']}`,
|
|
2312
|
+
"background-image": `url(${imagenDoc})`,
|
|
2313
|
+
"background-position": "center",
|
|
2314
|
+
"background-size": "30% 65%",
|
|
2315
|
+
"background-repeat": "no-repeat"
|
|
2316
|
+
};
|
|
2313
2317
|
this.fileSave.emit({ new: this.file });
|
|
2314
2318
|
}
|
|
2315
2319
|
else {
|
|
2316
|
-
|
|
2317
|
-
reader.onload = e => this.imageSrc = reader.result;
|
|
2318
|
-
reader.readAsDataURL(r);
|
|
2319
|
-
this.fileSave.emit({ new: this.file, compressor: r });
|
|
2320
|
+
this.message.Error('Error', 'Tipo de archivo no soportado');
|
|
2320
2321
|
}
|
|
2321
2322
|
}
|
|
2322
2323
|
else {
|
|
@@ -2346,10 +2347,10 @@ class FileInputComponent {
|
|
|
2346
2347
|
}
|
|
2347
2348
|
}
|
|
2348
2349
|
FileInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileInputComponent, deps: [{ token: FileFormsService }, { token: HttpService }, { token: MessageService }, { token: i1$2.UntypedFormBuilder }], target: i0.ɵɵFactoryTarget.Component });
|
|
2349
|
-
FileInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FileInputComponent, selector: "file-input", inputs: { params: "params", icon: "icon" }, outputs: { fileSave: "fileSave" }, ngImport: i0, template: "<div *ngIf=\"params.input == 'vista'\" [class]='edit' [ngStyle]=\"sizePicture\">\n\n\t<img [ngStyle]=\"styleImg\" src=\"{{this.imageSrc}}\">\n\n\t<div *ngIf=\"params.edit == true\" class=\"entrada\" [ngStyle]=\"border\">\n\t\t<input id=\"input\" type=\"file\" title='Subir archivo' [accept]='type'\n\t\t\tstyle='width: 100%; height: 100%; opacity: 0; overflow: hidden; z-index: 1; cursor: pointer;'\n\t\t\t(change)='fileChange($event)'>\n\t</div>\n\n</div>\n<div *ngIf=\"params.input == 'formulario'\">\n\n \t<!-- <mat-form-field [ngStyle]=\"styleForm\"> -->\n <!-- <ngx-mat-file-input [formControlName=\"file\" placeholder=\"Basic Input\">\n </ngx-mat-file-input> -->\n\n <!-- </mat-form-field> -->\n\n <mat-form-field [ngStyle]=\"styleForm\">\n <div style=\"display: flex;\">\n <input disabled type=\"text\" matInput [placeholder]=\"params.label\" readonly=\"true\">\n <input id=\"input\" type=\"file\" title='Subir archivo' [accept]='type'\n style='width: 100%; height: 100%; opacity: 0; overflow: hidden; z-index: 1; cursor: pointer;'\n (change)='fileChange($event)'>\n </div>\n <mat-icon *ngIf=\"typeFile=='imagen'\" matSuffix>add_a_photo</mat-icon>\n <mat-icon *ngIf=\"typeFile=='pdf'\" matSuffix>picture_as_pdf</mat-icon>\n\t\t <mat-icon *ngIf=\"typeFile=='doc'\" matSuffix>insert_drive_file</mat-icon>\n </mat-form-field>\n\n</div>\n", styles: ["p{font-family:Lato}.dropzone{min-height:400px;min-width:400px;display:table;width:100%;background-color:#eee;border:dotted 1px #aaa}.text-wrapper{display:table-cell;vertical-align:middle}.centered{font-family:sans-serif;font-size:1.3em;font-weight:700;text-align:center}.img :hover{background-image:url();background-color:#cfd0d5;background-position:center;background-size:25%;background-repeat:no-repeat;transition:background-color 1s;cursor:pointer}.img{position:relative}.entrada{position:absolute;top:0;right:0;width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i1$3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3$2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix]" }, { kind: "directive", type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }] });
|
|
2350
|
+
FileInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FileInputComponent, selector: "file-input", inputs: { params: "params", icon: "icon" }, outputs: { fileSave: "fileSave" }, ngImport: i0, template: "<div *ngIf=\"params.input == 'vista'\" [class]='edit' [ngStyle]=\"sizePicture\">\n \n <img *ngIf=\"imageSrc\" [ngStyle]=\"styleImg\" src=\"{{this.imageSrc}}\" />\n <div *ngIf=\"!imageSrc\" [ngStyle]=\"styleImg\"></div>\n\n\t<div *ngIf=\"params.edit == true\" class=\"entrada\" [ngStyle]=\"border\">\n\t\t<input id=\"input\" type=\"file\" title='Subir archivo' [accept]='type'\n\t\t\tstyle='width: 100%; height: 100%; opacity: 0; overflow: hidden; z-index: 1; cursor: pointer;'\n\t\t\t(change)='fileChange($event)'>\n\t</div>\n\n</div>\n<div *ngIf=\"params.input == 'formulario'\">\n\n \t<!-- <mat-form-field [ngStyle]=\"styleForm\"> -->\n <!-- <ngx-mat-file-input [formControlName=\"file\" placeholder=\"Basic Input\">\n </ngx-mat-file-input> -->\n\n <!-- </mat-form-field> -->\n\n <mat-form-field [ngStyle]=\"styleForm\">\n <div style=\"display: flex;\">\n <input disabled type=\"text\" matInput [placeholder]=\"params.label\" readonly=\"true\">\n <input id=\"input\" type=\"file\" title='Subir archivo' [accept]='type'\n style='width: 100%; height: 100%; opacity: 0; overflow: hidden; z-index: 1; cursor: pointer;'\n (change)='fileChange($event)'>\n </div>\n <mat-icon *ngIf=\"typeFile=='imagen'\" matSuffix>add_a_photo</mat-icon>\n <mat-icon *ngIf=\"typeFile=='pdf'\" matSuffix>picture_as_pdf</mat-icon>\n\t\t <mat-icon *ngIf=\"typeFile=='doc'\" matSuffix>insert_drive_file</mat-icon>\n </mat-form-field>\n\n</div>\n", styles: ["p{font-family:Lato}.dropzone{min-height:400px;min-width:400px;display:table;width:100%;background-color:#eee;border:dotted 1px #aaa}.text-wrapper{display:table-cell;vertical-align:middle}.centered{font-family:sans-serif;font-size:1.3em;font-weight:700;text-align:center}.img :hover{background-image:url();background-color:#cfd0d5;background-position:center;background-size:25%;background-repeat:no-repeat;transition:background-color 1s;cursor:pointer}.img{position:relative}.entrada{position:absolute;top:0;right:0;width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: i1$3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3$2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix]" }, { kind: "directive", type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }] });
|
|
2350
2351
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileInputComponent, decorators: [{
|
|
2351
2352
|
type: Component,
|
|
2352
|
-
args: [{ selector: 'file-input', template: "<div *ngIf=\"params.input == 'vista'\" [class]='edit' [ngStyle]=\"sizePicture\">\n\n\t<img [ngStyle]=\"styleImg\" src=\"{{this.imageSrc}}\">\n\n\t<div *ngIf=\"params.edit == true\" class=\"entrada\" [ngStyle]=\"border\">\n\t\t<input id=\"input\" type=\"file\" title='Subir archivo' [accept]='type'\n\t\t\tstyle='width: 100%; height: 100%; opacity: 0; overflow: hidden; z-index: 1; cursor: pointer;'\n\t\t\t(change)='fileChange($event)'>\n\t</div>\n\n</div>\n<div *ngIf=\"params.input == 'formulario'\">\n\n \t<!-- <mat-form-field [ngStyle]=\"styleForm\"> -->\n <!-- <ngx-mat-file-input [formControlName=\"file\" placeholder=\"Basic Input\">\n </ngx-mat-file-input> -->\n\n <!-- </mat-form-field> -->\n\n <mat-form-field [ngStyle]=\"styleForm\">\n <div style=\"display: flex;\">\n <input disabled type=\"text\" matInput [placeholder]=\"params.label\" readonly=\"true\">\n <input id=\"input\" type=\"file\" title='Subir archivo' [accept]='type'\n style='width: 100%; height: 100%; opacity: 0; overflow: hidden; z-index: 1; cursor: pointer;'\n (change)='fileChange($event)'>\n </div>\n <mat-icon *ngIf=\"typeFile=='imagen'\" matSuffix>add_a_photo</mat-icon>\n <mat-icon *ngIf=\"typeFile=='pdf'\" matSuffix>picture_as_pdf</mat-icon>\n\t\t <mat-icon *ngIf=\"typeFile=='doc'\" matSuffix>insert_drive_file</mat-icon>\n </mat-form-field>\n\n</div>\n", styles: ["p{font-family:Lato}.dropzone{min-height:400px;min-width:400px;display:table;width:100%;background-color:#eee;border:dotted 1px #aaa}.text-wrapper{display:table-cell;vertical-align:middle}.centered{font-family:sans-serif;font-size:1.3em;font-weight:700;text-align:center}.img :hover{background-image:url();background-color:#cfd0d5;background-position:center;background-size:25%;background-repeat:no-repeat;transition:background-color 1s;cursor:pointer}.img{position:relative}.entrada{position:absolute;top:0;right:0;width:100%;height:100%}\n"] }]
|
|
2353
|
+
args: [{ selector: 'file-input', template: "<div *ngIf=\"params.input == 'vista'\" [class]='edit' [ngStyle]=\"sizePicture\">\n \n <img *ngIf=\"imageSrc\" [ngStyle]=\"styleImg\" src=\"{{this.imageSrc}}\" />\n <div *ngIf=\"!imageSrc\" [ngStyle]=\"styleImg\"></div>\n\n\t<div *ngIf=\"params.edit == true\" class=\"entrada\" [ngStyle]=\"border\">\n\t\t<input id=\"input\" type=\"file\" title='Subir archivo' [accept]='type'\n\t\t\tstyle='width: 100%; height: 100%; opacity: 0; overflow: hidden; z-index: 1; cursor: pointer;'\n\t\t\t(change)='fileChange($event)'>\n\t</div>\n\n</div>\n<div *ngIf=\"params.input == 'formulario'\">\n\n \t<!-- <mat-form-field [ngStyle]=\"styleForm\"> -->\n <!-- <ngx-mat-file-input [formControlName=\"file\" placeholder=\"Basic Input\">\n </ngx-mat-file-input> -->\n\n <!-- </mat-form-field> -->\n\n <mat-form-field [ngStyle]=\"styleForm\">\n <div style=\"display: flex;\">\n <input disabled type=\"text\" matInput [placeholder]=\"params.label\" readonly=\"true\">\n <input id=\"input\" type=\"file\" title='Subir archivo' [accept]='type'\n style='width: 100%; height: 100%; opacity: 0; overflow: hidden; z-index: 1; cursor: pointer;'\n (change)='fileChange($event)'>\n </div>\n <mat-icon *ngIf=\"typeFile=='imagen'\" matSuffix>add_a_photo</mat-icon>\n <mat-icon *ngIf=\"typeFile=='pdf'\" matSuffix>picture_as_pdf</mat-icon>\n\t\t <mat-icon *ngIf=\"typeFile=='doc'\" matSuffix>insert_drive_file</mat-icon>\n </mat-form-field>\n\n</div>\n", styles: ["p{font-family:Lato}.dropzone{min-height:400px;min-width:400px;display:table;width:100%;background-color:#eee;border:dotted 1px #aaa}.text-wrapper{display:table-cell;vertical-align:middle}.centered{font-family:sans-serif;font-size:1.3em;font-weight:700;text-align:center}.img :hover{background-image:url();background-color:#cfd0d5;background-position:center;background-size:25%;background-repeat:no-repeat;transition:background-color 1s;cursor:pointer}.img{position:relative}.entrada{position:absolute;top:0;right:0;width:100%;height:100%}\n"] }]
|
|
2353
2354
|
}], ctorParameters: function () { return [{ type: FileFormsService }, { type: HttpService }, { type: MessageService }, { type: i1$2.UntypedFormBuilder }]; }, propDecorators: { params: [{
|
|
2354
2355
|
type: Input
|
|
2355
2356
|
}], fileSave: [{
|