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.
@@ -1772,13 +1772,13 @@ class DataTableComponent {
1772
1772
  let active = false;
1773
1773
  const allowedExtensions = [
1774
1774
  '.png', '.jpeg', '.jpg', '.gif', '.bmp', '.webp', '.svg',
1775
- '.pdf', '.doc', '.docx', '.xls', '.xlsx'
1775
+ '.pdf', '.doc', '.docx', '.xls', '.xlsx', '.document'
1776
1776
  ];
1777
1777
  rules.forEach(rule => {
1778
- if (rule.action === enumActions$1.SHOW_FILE_ICON && value && value.startsWith('/docs/')) {
1778
+ if (rule.action === enumActions$1.SHOW_FILE_ICON && value && value.includes('/docs/')) {
1779
1779
  const lowerValue = value.toLowerCase();
1780
1780
  for (const ext of allowedExtensions) {
1781
- if (lowerValue.endsWith(ext)) {
1781
+ if (lowerValue.includes(ext)) {
1782
1782
  active = true;
1783
1783
  break;
1784
1784
  }
@@ -2176,7 +2176,7 @@ class FileInputComponent {
2176
2176
  });
2177
2177
  this.sizePicture = {
2178
2178
  width: `${this.params.style.width}`,
2179
- height: `${this.params.style.height}`,
2179
+ height: this.params.style.height ? `${this.params.style.height}` : '200px',
2180
2180
  "border-radius": '5%',
2181
2181
  border: `${this.params.style.border}`,
2182
2182
  };
@@ -2186,7 +2186,17 @@ class FileInputComponent {
2186
2186
  else {
2187
2187
  this.edit = '';
2188
2188
  }
2189
- this.typeFile = this.params.typeFile;
2189
+ let types = Array.isArray(this.params.typeFile) ? this.params.typeFile : [this.params.typeFile];
2190
+ this.typeFile = types;
2191
+ this.type = types.map(t => {
2192
+ if (t === 'imagen')
2193
+ return 'image/*';
2194
+ if (t === 'pdf')
2195
+ return '.pdf';
2196
+ if (t === 'doc')
2197
+ return '.doc,.docx';
2198
+ return '';
2199
+ }).join(',');
2190
2200
  this.functionTypeFile();
2191
2201
  }
2192
2202
  functionTypeFile() {
@@ -2207,76 +2217,67 @@ class FileInputComponent {
2207
2217
  height: '100%',
2208
2218
  "border-radius": `${this.sizePicture['border-radius']}`,
2209
2219
  };
2210
- switch (this.typeFile) {
2211
- case 'imagen':
2212
- if (!this.params.imageSrc) {
2213
- this.imageSrc = imagenFondoTransparente;
2214
- }
2215
- else {
2216
- this.imageSrc = this.params.imageSrc;
2217
- }
2218
- this.type = 'image/*';
2219
- break;
2220
- case 'pdf':
2221
- this.type = '.pdf';
2222
- this.imageSrc = imagenFondoTransparente;
2223
- break;
2224
- case 'doc':
2225
- this.type = '.doc, .docx';
2226
- this.imageSrc = imagenFondoTransparente;
2227
- break;
2228
- default:
2229
- break;
2220
+ if (this.typeFile.includes('imagen')) {
2221
+ this.imageSrc = this.params.imageSrc || imagenFondoTransparente;
2222
+ }
2223
+ else {
2224
+ this.imageSrc = imagenFondoTransparente;
2230
2225
  }
2231
2226
  }
2232
2227
  async fileChange($event) {
2233
- if ($event.target['files'][0]['size'] < 15000000) {
2234
- let r;
2235
- if ($event.target['files'] && $event.target['files'][0]) {
2236
- this.file = $event.target['files'][0];
2237
- switch (this.typeFile) {
2238
- case 'pdf':
2239
- r = false;
2240
- this.styleImg = {
2241
- width: '100%',
2242
- height: '100%',
2243
- "border-radius": `${this.sizePicture['border-radius']}`,
2244
- "background-image": `url(${imagenPdf})`,
2245
- "background-position": "center",
2246
- "background-size": "30% 65%",
2247
- "background-repeat": "no-repeat"
2248
- };
2249
- break;
2250
- case 'imagen':
2251
- const reader = new FileReader();
2252
- reader.onload = e => this.imageSrc = reader.result;
2253
- reader.readAsDataURL(this.file);
2254
- r = await this.compressor();
2255
- break;
2256
- case 'doc':
2257
- r = false;
2258
- this.styleImg = {
2259
- width: '100%',
2260
- height: '100%',
2261
- "border-radius": `${this.sizePicture['border-radius']}`,
2262
- "background-image": `url(${imagenDoc})`,
2263
- "background-position": "center",
2264
- "background-size": "30% 65%",
2265
- "background-repeat": "no-repeat"
2266
- };
2267
- break;
2268
- default:
2269
- break;
2228
+ const file = $event.target['files'][0];
2229
+ if (!file)
2230
+ return;
2231
+ if (file.size < 15000000) {
2232
+ this.file = file;
2233
+ const mime = file.type;
2234
+ const name = file.name.toLowerCase();
2235
+ // NUEVO: Detectar tipo según archivo subido y lo permitido
2236
+ if (mime.startsWith('image/') && this.typeFile.includes('imagen')) {
2237
+ // Imagen
2238
+ const reader = new FileReader();
2239
+ reader.onload = e => this.imageSrc = reader.result;
2240
+ reader.readAsDataURL(this.file);
2241
+ const r = await this.compressor();
2242
+ if (r === false) {
2243
+ this.fileSave.emit({ new: this.file });
2270
2244
  }
2245
+ else {
2246
+ this.fileSave.emit({ new: this.file, compressor: r });
2247
+ }
2248
+ }
2249
+ else if ((mime === 'application/pdf' || name.endsWith('.pdf')) && this.typeFile.includes('pdf')) {
2250
+ // PDF
2251
+ this.imageSrc = '';
2252
+ this.styleImg = {
2253
+ width: '100%',
2254
+ height: '100%',
2255
+ "border-radius": `${this.sizePicture['border-radius']}`,
2256
+ "background-image": `url(${imagenPdf})`,
2257
+ "background-position": "center",
2258
+ "background-size": "30% 65%",
2259
+ "background-repeat": "no-repeat"
2260
+ };
2261
+ this.fileSave.emit({ new: this.file });
2271
2262
  }
2272
- if (r == false) {
2263
+ else if ((mime === 'application/msword' ||
2264
+ mime === 'application/vnd.openxmlformats-officedocument.wordprocessingml.document' ||
2265
+ name.endsWith('.doc') || name.endsWith('.docx')) && this.typeFile.includes('doc')) {
2266
+ // DOC/DOCX
2267
+ this.imageSrc = '';
2268
+ this.styleImg = {
2269
+ width: '100%',
2270
+ height: '100%',
2271
+ "border-radius": `${this.sizePicture['border-radius']}`,
2272
+ "background-image": `url(${imagenDoc})`,
2273
+ "background-position": "center",
2274
+ "background-size": "30% 65%",
2275
+ "background-repeat": "no-repeat"
2276
+ };
2273
2277
  this.fileSave.emit({ new: this.file });
2274
2278
  }
2275
2279
  else {
2276
- const reader = new FileReader();
2277
- reader.onload = e => this.imageSrc = reader.result;
2278
- reader.readAsDataURL(r);
2279
- this.fileSave.emit({ new: this.file, compressor: r });
2280
+ this.message.Error('Error', 'Tipo de archivo no soportado');
2280
2281
  }
2281
2282
  }
2282
2283
  else {
@@ -2305,10 +2306,10 @@ class FileInputComponent {
2305
2306
  }
2306
2307
  }
2307
2308
  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 });
2308
- 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"] }] });
2309
+ 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"] }] });
2309
2310
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FileInputComponent, decorators: [{
2310
2311
  type: Component,
2311
- 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"] }]
2312
+ 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"] }]
2312
2313
  }], ctorParameters: function () { return [{ type: FileFormsService }, { type: HttpService }, { type: MessageService }, { type: i1$2.UntypedFormBuilder }]; }, propDecorators: { params: [{
2313
2314
  type: Input
2314
2315
  }], fileSave: [{