keevo-components 1.8.435 → 1.8.437
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/esm2022/lib/components/kv-file-upload/kv-file-upload.component.mjs +32 -9
- package/esm2022/lib/components/kv-loader/kv-loader.component.mjs +5 -6
- package/esm2022/lib/components/kv-loader/kv-loader.service.mjs +6 -6
- package/esm2022/lib/components/kv-tree-table/kv-tree-table.component.mjs +3 -3
- package/fesm2022/keevo-components.mjs +42 -19
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/lib/components/kv-file-upload/kv-file-upload.component.d.ts +2 -1
- package/lib/components/kv-loader/kv-loader.component.d.ts +2 -3
- package/lib/components/kv-loader/kv-loader.service.d.ts +2 -2
- package/lib/components/kv-table/kv-table.component.d.ts +1 -1
- package/lib/components/kv-table-expandable/kv-table-expandable.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -8,15 +8,24 @@ export class KvFileUploadComponent {
|
|
|
8
8
|
this.widthComponent = '400px';
|
|
9
9
|
this.heightComponent = 'auto';
|
|
10
10
|
this.validFileTypes = ['image/', 'application/pdf', 'text/html'];
|
|
11
|
+
this.includeOfficeTypes = false; // Propriedade para controlar os tipos de Office
|
|
11
12
|
this.fileEmit = new EventEmitter();
|
|
12
13
|
this.removeFileEmit = new EventEmitter();
|
|
13
14
|
}
|
|
14
15
|
onFileSelected(event) {
|
|
16
|
+
let validTypes = [...this.validFileTypes];
|
|
17
|
+
if (this.includeOfficeTypes) {
|
|
18
|
+
validTypes.push('application/msword', // .doc
|
|
19
|
+
'application/vnd.openxmlformats-officedocument.wordprocessingml.document', // .docx
|
|
20
|
+
'application/vnd.ms-powerpoint', // .ppt
|
|
21
|
+
'application/vnd.openxmlformats-officedocument.presentationml.presentation' // .pptx
|
|
22
|
+
);
|
|
23
|
+
}
|
|
15
24
|
if (event.target.files.length == 0)
|
|
16
25
|
return;
|
|
17
|
-
const isValidFileType =
|
|
26
|
+
const isValidFileType = validTypes.some(type => event.target.files[0].type.startsWith(type));
|
|
18
27
|
if (!isValidFileType) {
|
|
19
|
-
this.notificationService.toastError(
|
|
28
|
+
this.notificationService.toastError('Tipo de arquivo inválido');
|
|
20
29
|
this.formGroup.controls[this.formControlName].setValue(null);
|
|
21
30
|
return;
|
|
22
31
|
}
|
|
@@ -46,6 +55,14 @@ export class KvFileUploadComponent {
|
|
|
46
55
|
container.classList.remove('dragover');
|
|
47
56
|
}
|
|
48
57
|
handleFile(file) {
|
|
58
|
+
if (this.includeOfficeTypes) {
|
|
59
|
+
let validTypes = [...this.validFileTypes];
|
|
60
|
+
validTypes.push('application/msword', // .doc
|
|
61
|
+
'application/vnd.openxmlformats-officedocument.wordprocessingml.document', // .docx
|
|
62
|
+
'application/vnd.ms-powerpoint', // .ppt
|
|
63
|
+
'application/vnd.openxmlformats-officedocument.presentationml.presentation' // .pptx
|
|
64
|
+
);
|
|
65
|
+
}
|
|
49
66
|
const isValidFileType = this.validFileTypes.some(type => file.type.startsWith(type));
|
|
50
67
|
if (!isValidFileType) {
|
|
51
68
|
this.notificationService.toastError('Tipo de arquivo inválido');
|
|
@@ -57,7 +74,7 @@ export class KvFileUploadComponent {
|
|
|
57
74
|
if (file.type.startsWith('image/'))
|
|
58
75
|
reader.readAsDataURL(file);
|
|
59
76
|
else
|
|
60
|
-
reader.readAsArrayBuffer(file); // Para outros tipos de arquivo
|
|
77
|
+
reader.readAsArrayBuffer(file); // Para outros tipos de arquivo
|
|
61
78
|
this.fileEmit.emit(file);
|
|
62
79
|
}
|
|
63
80
|
onDragOver(event) {
|
|
@@ -82,16 +99,20 @@ export class KvFileUploadComponent {
|
|
|
82
99
|
let types = '';
|
|
83
100
|
this.validFileTypes.forEach(type => {
|
|
84
101
|
if (type.includes('image'))
|
|
85
|
-
types += '.jpg, .png, .bmp';
|
|
102
|
+
types += '.jpg, .png, .bmp, ';
|
|
86
103
|
if (type.includes('html'))
|
|
87
|
-
types += '.html';
|
|
104
|
+
types += '.html, ';
|
|
88
105
|
if (type.includes('pdf'))
|
|
89
|
-
types += '.pdf';
|
|
106
|
+
types += '.pdf, ';
|
|
90
107
|
});
|
|
91
|
-
|
|
108
|
+
// Adiciona tipos de arquivos do Office se includeOfficeTypes for true
|
|
109
|
+
if (this.includeOfficeTypes) {
|
|
110
|
+
types += '.doc, .docx, .ppt, .pptx, ';
|
|
111
|
+
}
|
|
112
|
+
return types.slice(0, -2); // Remove a última vírgula e espaço
|
|
92
113
|
}
|
|
93
114
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvFileUploadComponent, deps: [{ token: i1.NotificationService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
94
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvFileUploadComponent, selector: "kv-file-upload", inputs: { formGroup: "formGroup", formControlName: "formControlName", widthComponent: "widthComponent", heightComponent: "heightComponent", description: "description", validFileTypes: "validFileTypes" }, outputs: { fileEmit: "fileEmit", removeFileEmit: "removeFileEmit" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }, { propertyName: "inputUpload", first: true, predicate: ["inputUpload"], descendants: true }], ngImport: i0, template: "<div\r\n *ngIf=\"formGroup\"\r\n [ngClass]=\"{'invalid-border': formGroup && formControlName && formGroup.controls[formControlName].invalid && formGroup.controls[formControlName].touched}\"\r\n class=\"border-dashed border-2 border-round-lg border-gray-400 flex justify-content-end\"\r\n (dragover)=\"onDragOver($event)\"\r\n (dragleave)=\"onDragLeave($event)\"\r\n (drop)=\"onDrop($event)\"\r\n [style.width]=\"widthComponent\"\r\n [style.height]=\"heightComponent\">\r\n\r\n <div class=\"field col-12 flex justify-content-center align-items-center flex-column\">\r\n <div\r\n class=\"w-full flex align-items-center justify-content-center\"\r\n style=\"cursor: pointer;\"\r\n (click)=\"fileInput.click()\">\r\n\r\n <input type=\"file\" (change)=\"onFileSelected($event)\" #fileInput [accept]=\"setAccept()\" hidden/>\r\n\r\n @if(formGroup && formControlName && !formGroup.controls[formControlName].value) {\r\n <div class=\"flex flex-column align-items-center justify-content-center\">\r\n <span class=\"material-symbols-outlined mt-2\" style=\"font-size: 3rem;\">\r\n cloud_upload\r\n </span>\r\n\r\n @if(description) {\r\n <p class=\"font-semibold text-center\">{{description}}</p>\r\n } @else {\r\n <p class=\"font-semibold text-center\">Arraste e solte o arquivo aqui, ou<br>clique para selecion\u00E1-lo</p>\r\n }\r\n </div>\r\n }\r\n </div>\r\n\r\n @if(formGroup && formControlName && formGroup.controls[formControlName].value) {\r\n <div class=\"flex flex-column\">\r\n <span class=\"font-semibold\" style=\"padding: 10px;\">Arquivo Selecionado:</span>\r\n <div class=\"flex flex-row\">\r\n <span style=\"padding: 10px;\">{{ formGroup.controls[formControlName].value?.name }}</span>\r\n <span style=\"padding: 10px;\">({{ formatBytes(formGroup.controls[formControlName].value?.size) }})</span>\r\n <i style=\"padding: 10px; margin-left: 10px;\"\r\n pTooltip=\"Excluir arquivo\"\r\n class=\"border-solid border-1 border-round-sm border-gray-400 pi pi-trash delete cursor-pointer\"\r\n (click)=\"deleteFile()\"\r\n ></i>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n</div>\r\n\r\n@if (formGroup && formControlName && formGroup.controls[formControlName].invalid && formGroup.controls[formControlName].touched) {\r\n <p class=\"error-message\">Campo obrigat\u00F3rio</p>\r\n}\r\n", styles: [".invalid-border{border:2px dashed red!important}.error-message{color:#ff0e0e;font-size:12px!important;margin-top:.1rem}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
115
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvFileUploadComponent, selector: "kv-file-upload", inputs: { formGroup: "formGroup", formControlName: "formControlName", widthComponent: "widthComponent", heightComponent: "heightComponent", description: "description", validFileTypes: "validFileTypes", includeOfficeTypes: "includeOfficeTypes" }, outputs: { fileEmit: "fileEmit", removeFileEmit: "removeFileEmit" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }, { propertyName: "inputUpload", first: true, predicate: ["inputUpload"], descendants: true }], ngImport: i0, template: "<div\r\n *ngIf=\"formGroup\"\r\n [ngClass]=\"{'invalid-border': formGroup && formControlName && formGroup.controls[formControlName].invalid && formGroup.controls[formControlName].touched}\"\r\n class=\"border-dashed border-2 border-round-lg border-gray-400 flex justify-content-end\"\r\n (dragover)=\"onDragOver($event)\"\r\n (dragleave)=\"onDragLeave($event)\"\r\n (drop)=\"onDrop($event)\"\r\n [style.width]=\"widthComponent\"\r\n [style.height]=\"heightComponent\">\r\n\r\n <div class=\"field col-12 flex justify-content-center align-items-center flex-column\">\r\n <div\r\n class=\"w-full flex align-items-center justify-content-center\"\r\n style=\"cursor: pointer;\"\r\n (click)=\"fileInput.click()\">\r\n\r\n <input type=\"file\" (change)=\"onFileSelected($event)\" #fileInput [accept]=\"setAccept()\" hidden/>\r\n\r\n @if(formGroup && formControlName && !formGroup.controls[formControlName].value) {\r\n <div class=\"flex flex-column align-items-center justify-content-center\">\r\n <span class=\"material-symbols-outlined mt-2\" style=\"font-size: 3rem;\">\r\n cloud_upload\r\n </span>\r\n\r\n @if(description) {\r\n <p class=\"font-semibold text-center\">{{description}}</p>\r\n } @else {\r\n <p class=\"font-semibold text-center\">Arraste e solte o arquivo aqui, ou<br>clique para selecion\u00E1-lo</p>\r\n }\r\n </div>\r\n }\r\n </div>\r\n\r\n @if(formGroup && formControlName && formGroup.controls[formControlName].value) {\r\n <div class=\"flex flex-column\">\r\n <span class=\"font-semibold\" style=\"padding: 10px;\">Arquivo Selecionado:</span>\r\n <div class=\"flex flex-row\">\r\n <span style=\"padding: 10px;\">{{ formGroup.controls[formControlName].value?.name }}</span>\r\n <span style=\"padding: 10px;\">({{ formatBytes(formGroup.controls[formControlName].value?.size) }})</span>\r\n <i style=\"padding: 10px; margin-left: 10px;\"\r\n pTooltip=\"Excluir arquivo\"\r\n class=\"border-solid border-1 border-round-sm border-gray-400 pi pi-trash delete cursor-pointer\"\r\n (click)=\"deleteFile()\"\r\n ></i>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n</div>\r\n\r\n@if (formGroup && formControlName && formGroup.controls[formControlName].invalid && formGroup.controls[formControlName].touched) {\r\n <p class=\"error-message\">Campo obrigat\u00F3rio</p>\r\n}\r\n", styles: [".invalid-border{border:2px dashed red!important}.error-message{color:#ff0e0e;font-size:12px!important;margin-top:.1rem}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
95
116
|
}
|
|
96
117
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvFileUploadComponent, decorators: [{
|
|
97
118
|
type: Component,
|
|
@@ -108,6 +129,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
108
129
|
type: Input
|
|
109
130
|
}], validFileTypes: [{
|
|
110
131
|
type: Input
|
|
132
|
+
}], includeOfficeTypes: [{
|
|
133
|
+
type: Input
|
|
111
134
|
}], fileEmit: [{
|
|
112
135
|
type: Output
|
|
113
136
|
}], removeFileEmit: [{
|
|
@@ -119,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
119
142
|
type: ViewChild,
|
|
120
143
|
args: ['inputUpload']
|
|
121
144
|
}] } });
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-file-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-file-upload/kv-file-upload.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-file-upload/kv-file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ViewChild, ElementRef  } from '@angular/core';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { NotificationService } from '../../api/services/notification.service';\r\n\r\n\r\n@Component({\r\n  selector: 'kv-file-upload',\r\n  templateUrl: './kv-file-upload.component.html',\r\n  styleUrl: './kv-file-upload.component.scss'\r\n})\r\nexport class KvFileUploadComponent {\r\n  @Input() formGroup!: FormGroup;\r\n  @Input() formControlName!: string;\r\n  @Input() widthComponent: string = '400px';\r\n  @Input() heightComponent: string = 'auto';\r\n  @Input() description!: string;\r\n  @Input() validFileTypes: string[] = ['image/', 'application/pdf', 'text/html'];\r\n\r\n  @Output() fileEmit: EventEmitter<any> = new EventEmitter();\r\n  @Output() removeFileEmit: EventEmitter<any> = new EventEmitter();\r\n\r\n  @ViewChild('fileInput') fileInput!: ElementRef;\r\n  @ViewChild('inputUpload') inputUpload!: ElementRef;\r\n\r\n  constructor(\r\n    private notificationService: NotificationService\r\n  ) { }\r\n\r\n  onFileSelected(event: any): void {\r\n    if (event.target.files.length == 0)\r\n      return\r\n\r\n    const isValidFileType = this.validFileTypes.some(type => event.target.files[0].type.startsWith(type));\r\n\r\n    if (!isValidFileType) {\r\n      this.notificationService.toastError(\"Tipo de arquivo inválido\")\r\n      this.formGroup.controls[this.formControlName].setValue(null);\r\n      return\r\n    }\r\n\r\n    this.formGroup.controls[this.formControlName].setValue(event.target.files[0]);\r\n  }\r\n\r\n  deleteFile() {\r\n    this.formGroup.controls[this.formControlName].setValue(null);\r\n    this.fileInput.nativeElement.value = '';\r\n    this.removeFileEmit.emit();\r\n  }\r\n\r\n  formatBytes(bytes: any, decimals = 2) {\r\n    if (!bytes) {\r\n      return \"0 Bytes\";\r\n    }\r\n    const k = 1024;\r\n    const dm = decimals <= 0 ? 0 : decimals;\r\n    const sizes = [\"Bytes\", \"KB\", \"MB\", \"GB\", \"TB\", \"PB\", \"EB\", \"ZB\", \"YB\"];\r\n    const i = Math.floor(Math.log(bytes) / Math.log(k));\r\n    return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + \" \" + sizes[i];\r\n  }\r\n\r\n  addDragOverClass(event: DragEvent) {\r\n    const container = event.target as HTMLElement;\r\n    container.classList.add('dragover');\r\n  }\r\n\r\n  removeDragOverClass(event: DragEvent) {\r\n    const container = event.target as HTMLElement;\r\n    container.classList.remove('dragover');\r\n  }\r\n\r\n  handleFile(file: File) {\r\n    const isValidFileType = this.validFileTypes.some(type => file.type.startsWith(type));\r\n\r\n    if (!isValidFileType) {\r\n      this.notificationService.toastError('Tipo de arquivo inválido');\r\n      this.formGroup.controls[this.formControlName].setValue(null);\r\n      return\r\n    }\r\n\r\n    this.formGroup.controls[this.formControlName].setValue(file);\r\n\r\n    const reader = new FileReader();\r\n\r\n    if (file.type.startsWith('image/'))\r\n      reader.readAsDataURL(file);\r\n    else\r\n      reader.readAsArrayBuffer(file); // Para outros tipos de arquivo, use readAsArrayBuffer ou outro método apropriado\r\n\r\n    this.fileEmit.emit(file);\r\n  }\r\n\r\n  onDragOver(event: DragEvent) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.addDragOverClass(event);\r\n  }\r\n\r\n  onDragLeave(event: DragEvent) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.removeDragOverClass(event);\r\n  }\r\n\r\n  onDrop(event: DragEvent) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.removeDragOverClass(event);\r\n\r\n    if (event.dataTransfer && event.dataTransfer.files.length > 0) {\r\n      this.handleFile(event.dataTransfer.files[0]);\r\n    }\r\n  }\r\n\r\n  setAccept(): string {\r\n    let types = ''\r\n\r\n    this.validFileTypes.forEach(type => {\r\n      if (type.includes('image'))\r\n        types += '.jpg, .png, .bmp';\r\n\r\n      if (type.includes('html'))\r\n        types += '.html';\r\n\r\n      if (type.includes('pdf'))\r\n        types += '.pdf';\r\n    });\r\n\r\n    return types;\r\n  }\r\n}\r\n","<div\r\n    *ngIf=\"formGroup\"\r\n    [ngClass]=\"{'invalid-border': formGroup && formControlName && formGroup.controls[formControlName].invalid && formGroup.controls[formControlName].touched}\"\r\n    class=\"border-dashed border-2 border-round-lg border-gray-400 flex justify-content-end\"\r\n    (dragover)=\"onDragOver($event)\"\r\n    (dragleave)=\"onDragLeave($event)\"\r\n    (drop)=\"onDrop($event)\"\r\n    [style.width]=\"widthComponent\"\r\n    [style.height]=\"heightComponent\">\r\n\r\n  <div class=\"field col-12 flex justify-content-center align-items-center flex-column\">\r\n    <div\r\n      class=\"w-full flex align-items-center justify-content-center\"\r\n      style=\"cursor: pointer;\"\r\n      (click)=\"fileInput.click()\">\r\n\r\n      <input type=\"file\" (change)=\"onFileSelected($event)\" #fileInput [accept]=\"setAccept()\" hidden/>\r\n\r\n      @if(formGroup && formControlName && !formGroup.controls[formControlName].value) {\r\n        <div class=\"flex flex-column align-items-center justify-content-center\">\r\n            <span class=\"material-symbols-outlined mt-2\" style=\"font-size: 3rem;\">\r\n                cloud_upload\r\n            </span>\r\n\r\n            @if(description) {\r\n                <p class=\"font-semibold text-center\">{{description}}</p>\r\n            } @else {\r\n                <p class=\"font-semibold text-center\">Arraste e solte o arquivo aqui, ou<br>clique para selecioná-lo</p>\r\n            }\r\n        </div>\r\n      }\r\n    </div>\r\n\r\n    @if(formGroup && formControlName && formGroup.controls[formControlName].value) {\r\n      <div class=\"flex flex-column\">\r\n          <span class=\"font-semibold\" style=\"padding: 10px;\">Arquivo Selecionado:</span>\r\n          <div class=\"flex flex-row\">\r\n              <span style=\"padding: 10px;\">{{ formGroup.controls[formControlName].value?.name }}</span>\r\n              <span style=\"padding: 10px;\">({{ formatBytes(formGroup.controls[formControlName].value?.size) }})</span>\r\n              <i  style=\"padding: 10px; margin-left: 10px;\"\r\n                  pTooltip=\"Excluir arquivo\"\r\n                  class=\"border-solid border-1 border-round-sm border-gray-400 pi pi-trash delete cursor-pointer\"\r\n                  (click)=\"deleteFile()\"\r\n              ></i>\r\n          </div>\r\n      </div>\r\n    }\r\n  </div>\r\n</div>\r\n\r\n@if (formGroup && formControlName && formGroup.controls[formControlName].invalid && formGroup.controls[formControlName].touched)  {\r\n  <p class=\"error-message\">Campo obrigatório</p>\r\n}\r\n"]}
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-file-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-file-upload/kv-file-upload.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-file-upload/kv-file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ViewChild, ElementRef } from '@angular/core';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { NotificationService } from '../../api/services/notification.service';\r\n\r\n@Component({\r\n  selector: 'kv-file-upload',\r\n  templateUrl: './kv-file-upload.component.html',\r\n  styleUrl: './kv-file-upload.component.scss'\r\n})\r\nexport class KvFileUploadComponent {\r\n  @Input() formGroup!: FormGroup;\r\n  @Input() formControlName!: string;\r\n  @Input() widthComponent: string = '400px';\r\n  @Input() heightComponent: string = 'auto';\r\n  @Input() description!: string;\r\n  @Input() validFileTypes: string[] = ['image/', 'application/pdf', 'text/html'];\r\n  @Input() includeOfficeTypes: boolean = false; // Propriedade para controlar os tipos de Office\r\n\r\n  @Output() fileEmit: EventEmitter<any> = new EventEmitter();\r\n  @Output() removeFileEmit: EventEmitter<any> = new EventEmitter();\r\n\r\n  @ViewChild('fileInput') fileInput!: ElementRef;\r\n  @ViewChild('inputUpload') inputUpload!: ElementRef;\r\n\r\n  constructor(private notificationService: NotificationService) { }\r\n\r\n  onFileSelected(event: any): void {\r\n    let validTypes = [...this.validFileTypes];\r\n\r\n    if (this.includeOfficeTypes) {\r\n  \r\n      validTypes.push(\r\n        'application/msword', // .doc\r\n        'application/vnd.openxmlformats-officedocument.wordprocessingml.document', // .docx\r\n        'application/vnd.ms-powerpoint', // .ppt\r\n        'application/vnd.openxmlformats-officedocument.presentationml.presentation' // .pptx\r\n      );\r\n    }\r\n\r\n    if (event.target.files.length == 0) return;\r\n\r\n    const isValidFileType = validTypes.some(type => event.target.files[0].type.startsWith(type));\r\n    if (!isValidFileType) {\r\n      this.notificationService.toastError('Tipo de arquivo inválido');\r\n      this.formGroup.controls[this.formControlName].setValue(null);\r\n      return;\r\n    }\r\n\r\n    this.formGroup.controls[this.formControlName].setValue(event.target.files[0]);\r\n  }\r\n\r\n  deleteFile() {\r\n    this.formGroup.controls[this.formControlName].setValue(null);\r\n    this.fileInput.nativeElement.value = '';\r\n    this.removeFileEmit.emit();\r\n  }\r\n\r\n  formatBytes(bytes: any, decimals = 2) {\r\n    if (!bytes) {\r\n      return \"0 Bytes\";\r\n    }\r\n    const k = 1024;\r\n    const dm = decimals <= 0 ? 0 : decimals;\r\n    const sizes = [\"Bytes\", \"KB\", \"MB\", \"GB\", \"TB\", \"PB\", \"EB\", \"ZB\", \"YB\"];\r\n    const i = Math.floor(Math.log(bytes) / Math.log(k));\r\n    return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + \" \" + sizes[i];\r\n  }\r\n\r\n  addDragOverClass(event: DragEvent) {\r\n    const container = event.target as HTMLElement;\r\n    container.classList.add('dragover');\r\n  }\r\n\r\n  removeDragOverClass(event: DragEvent) {\r\n    const container = event.target as HTMLElement;\r\n    container.classList.remove('dragover');\r\n  }\r\n\r\n  handleFile(file: File) {\r\n\r\n\r\n  if (this.includeOfficeTypes) {\r\n    let validTypes = [...this.validFileTypes];\r\n\r\n    validTypes.push(\r\n      'application/msword', // .doc\r\n      'application/vnd.openxmlformats-officedocument.wordprocessingml.document', // .docx\r\n      'application/vnd.ms-powerpoint', // .ppt\r\n      'application/vnd.openxmlformats-officedocument.presentationml.presentation' // .pptx\r\n    );\r\n  }\r\n\r\n    const isValidFileType = this.validFileTypes.some(type => file.type.startsWith(type));\r\n\r\n    if (!isValidFileType) {\r\n      this.notificationService.toastError('Tipo de arquivo inválido');\r\n      this.formGroup.controls[this.formControlName].setValue(null);\r\n      return;\r\n    }\r\n\r\n    this.formGroup.controls[this.formControlName].setValue(file);\r\n\r\n    const reader = new FileReader();\r\n\r\n    if (file.type.startsWith('image/'))\r\n      reader.readAsDataURL(file);\r\n    else\r\n      reader.readAsArrayBuffer(file); // Para outros tipos de arquivo\r\n\r\n    this.fileEmit.emit(file);\r\n  }\r\n\r\n  onDragOver(event: DragEvent) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.addDragOverClass(event);\r\n  }\r\n\r\n  onDragLeave(event: DragEvent) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.removeDragOverClass(event);\r\n  }\r\n\r\n  onDrop(event: DragEvent) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.removeDragOverClass(event);\r\n\r\n    if (event.dataTransfer && event.dataTransfer.files.length > 0) {\r\n      this.handleFile(event.dataTransfer.files[0]);\r\n    }\r\n  }\r\n\r\n  setAccept(): string {\r\n    let types = ''\r\n\r\n    this.validFileTypes.forEach(type => {\r\n      if (type.includes('image')) types += '.jpg, .png, .bmp, ';\r\n      if (type.includes('html')) types += '.html, ';\r\n      if (type.includes('pdf')) types += '.pdf, ';\r\n    });\r\n\r\n    // Adiciona tipos de arquivos do Office se includeOfficeTypes for true\r\n    if (this.includeOfficeTypes) {\r\n      types += '.doc, .docx, .ppt, .pptx, ';\r\n    }\r\n\r\n    return types.slice(0, -2); // Remove a última vírgula e espaço\r\n  }\r\n}\r\n","<div\r\n    *ngIf=\"formGroup\"\r\n    [ngClass]=\"{'invalid-border': formGroup && formControlName && formGroup.controls[formControlName].invalid && formGroup.controls[formControlName].touched}\"\r\n    class=\"border-dashed border-2 border-round-lg border-gray-400 flex justify-content-end\"\r\n    (dragover)=\"onDragOver($event)\"\r\n    (dragleave)=\"onDragLeave($event)\"\r\n    (drop)=\"onDrop($event)\"\r\n    [style.width]=\"widthComponent\"\r\n    [style.height]=\"heightComponent\">\r\n\r\n  <div class=\"field col-12 flex justify-content-center align-items-center flex-column\">\r\n    <div\r\n      class=\"w-full flex align-items-center justify-content-center\"\r\n      style=\"cursor: pointer;\"\r\n      (click)=\"fileInput.click()\">\r\n\r\n      <input type=\"file\" (change)=\"onFileSelected($event)\" #fileInput [accept]=\"setAccept()\" hidden/>\r\n\r\n      @if(formGroup && formControlName && !formGroup.controls[formControlName].value) {\r\n        <div class=\"flex flex-column align-items-center justify-content-center\">\r\n            <span class=\"material-symbols-outlined mt-2\" style=\"font-size: 3rem;\">\r\n                cloud_upload\r\n            </span>\r\n\r\n            @if(description) {\r\n                <p class=\"font-semibold text-center\">{{description}}</p>\r\n            } @else {\r\n                <p class=\"font-semibold text-center\">Arraste e solte o arquivo aqui, ou<br>clique para selecioná-lo</p>\r\n            }\r\n        </div>\r\n      }\r\n    </div>\r\n\r\n    @if(formGroup && formControlName && formGroup.controls[formControlName].value) {\r\n      <div class=\"flex flex-column\">\r\n          <span class=\"font-semibold\" style=\"padding: 10px;\">Arquivo Selecionado:</span>\r\n          <div class=\"flex flex-row\">\r\n              <span style=\"padding: 10px;\">{{ formGroup.controls[formControlName].value?.name }}</span>\r\n              <span style=\"padding: 10px;\">({{ formatBytes(formGroup.controls[formControlName].value?.size) }})</span>\r\n              <i  style=\"padding: 10px; margin-left: 10px;\"\r\n                  pTooltip=\"Excluir arquivo\"\r\n                  class=\"border-solid border-1 border-round-sm border-gray-400 pi pi-trash delete cursor-pointer\"\r\n                  (click)=\"deleteFile()\"\r\n              ></i>\r\n          </div>\r\n      </div>\r\n    }\r\n  </div>\r\n</div>\r\n\r\n@if (formGroup && formControlName && formGroup.controls[formControlName].invalid && formGroup.controls[formControlName].touched)  {\r\n  <p class=\"error-message\">Campo obrigatório</p>\r\n}\r\n"]}
|
|
@@ -2,16 +2,15 @@ import { Component } from '@angular/core';
|
|
|
2
2
|
import { KvLoaderService } from './kv-loader.service';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "ngx-loading";
|
|
5
|
-
import * as i2 from "@angular/common";
|
|
6
5
|
export class KvLoaderComponent {
|
|
7
6
|
constructor() {
|
|
8
|
-
this.loading = KvLoaderService.
|
|
7
|
+
this.loading = KvLoaderService.loading;
|
|
9
8
|
}
|
|
10
9
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvLoaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
11
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: KvLoaderComponent, selector: "kv-loader", ngImport: i0, template: "<ngx-loading [show]=\"(
|
|
10
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: KvLoaderComponent, selector: "kv-loader", ngImport: i0, template: "<ngx-loading [show]=\"loading() > 0\"></ngx-loading>\r\n", dependencies: [{ kind: "component", type: i1.NgxLoadingComponent, selector: "ngx-loading", inputs: ["show", "config", "template"] }] }); }
|
|
12
11
|
}
|
|
13
12
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvLoaderComponent, decorators: [{
|
|
14
13
|
type: Component,
|
|
15
|
-
args: [{ selector: 'kv-loader', template: "<ngx-loading [show]=\"(
|
|
16
|
-
}]
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
args: [{ selector: 'kv-loader', template: "<ngx-loading [show]=\"loading() > 0\"></ngx-loading>\r\n" }]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtbG9hZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LWxvYWRlci9rdi1sb2FkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtbG9hZGVyL2t2LWxvYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFlLE1BQU0sZUFBZSxDQUFDO0FBRXZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQzs7O0FBTXRELE1BQU0sT0FBTyxpQkFBaUI7SUFKOUI7UUFLUyxZQUFPLEdBQW1CLGVBQWUsQ0FBQyxPQUFPLENBQUM7S0FDMUQ7OEdBRlksaUJBQWlCO2tHQUFqQixpQkFBaUIsaURDUjlCLDBEQUNBOzsyRkRPYSxpQkFBaUI7a0JBSjdCLFNBQVM7K0JBQ0UsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgdHlwZSBTaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IEt2TG9hZGVyU2VydmljZSB9IGZyb20gJy4va3YtbG9hZGVyLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdrdi1sb2FkZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9rdi1sb2FkZXIuY29tcG9uZW50Lmh0bWwnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLdkxvYWRlckNvbXBvbmVudCB7XHJcbiAgcHVibGljIGxvYWRpbmc6IFNpZ25hbDxudW1iZXI+ID0gS3ZMb2FkZXJTZXJ2aWNlLmxvYWRpbmc7XHJcbn1cclxuIiwiPG5neC1sb2FkaW5nIFtzaG93XT1cImxvYWRpbmcoKSA+IDBcIj48L25neC1sb2FkaW5nPlxyXG4iXX0=
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import {
|
|
1
|
+
import { Injectable, signal } from '@angular/core';
|
|
2
|
+
import { finalize, } from 'rxjs';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class KvLoaderService {
|
|
5
|
-
static { this.
|
|
5
|
+
static { this.loading = signal(0); }
|
|
6
6
|
static show() {
|
|
7
|
-
|
|
7
|
+
KvLoaderService.loading.update(x => x + 1);
|
|
8
8
|
}
|
|
9
9
|
static hide() {
|
|
10
|
-
|
|
10
|
+
KvLoaderService.loading.update(x => x - 1);
|
|
11
11
|
}
|
|
12
12
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvLoaderService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
13
13
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvLoaderService, providedIn: 'root' }); }
|
|
@@ -26,4 +26,4 @@ export const loading = () => {
|
|
|
26
26
|
}));
|
|
27
27
|
};
|
|
28
28
|
};
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtbG9hZGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9rdi1sb2FkZXIva3YtbG9hZGVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUVMLFFBQVEsR0FDVCxNQUFNLE1BQU0sQ0FBQzs7QUFLZCxNQUFNLE9BQU8sZUFBZTthQUNaLFlBQU8sR0FBRyxNQUFNLENBQUMsQ0FBQyxDQUFDLEFBQVosQ0FBYTtJQUUzQixNQUFNLENBQUMsSUFBSTtRQUNoQixlQUFlLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRU0sTUFBTSxDQUFDLElBQUk7UUFDaEIsZUFBZSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDN0MsQ0FBQzs4R0FUVSxlQUFlO2tIQUFmLGVBQWUsY0FGZCxNQUFNOzsyRkFFUCxlQUFlO2tCQUgzQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQjs7QUFhRCxNQUFNLENBQUMsTUFBTSxPQUFPLEdBQUcsR0FBNkMsRUFBRTtJQUNwRSxPQUFPLENBQUMsR0FBa0IsRUFBRSxFQUFFO1FBQzVCLGVBQWUsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN2QixPQUFPLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUM1QixlQUFlLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDekIsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNOLENBQUMsQ0FBQztBQUNKLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUsIHNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge1xyXG4gIE9ic2VydmFibGUsXHJcbiAgZmluYWxpemUsXHJcbn0gZnJvbSAncnhqcyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLdkxvYWRlclNlcnZpY2Uge1xyXG4gIHB1YmxpYyBzdGF0aWMgbG9hZGluZyA9IHNpZ25hbCgwKTtcclxuXHJcbiAgcHVibGljIHN0YXRpYyBzaG93KCkge1xyXG4gICAgS3ZMb2FkZXJTZXJ2aWNlLmxvYWRpbmcudXBkYXRlKHggPT4geCArIDEpO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHN0YXRpYyBoaWRlKCkge1xyXG4gICAgS3ZMb2FkZXJTZXJ2aWNlLmxvYWRpbmcudXBkYXRlKHggPT4geCAtIDEpO1xyXG4gIH1cclxufVxyXG5cclxuZXhwb3J0IGNvbnN0IGxvYWRpbmcgPSA8VD4oKTogKHNyYzogT2JzZXJ2YWJsZTxUPikgPT4gT2JzZXJ2YWJsZTxUPiA9PiB7XHJcbiAgcmV0dXJuIChzcmM6IE9ic2VydmFibGU8VD4pID0+IHtcclxuICAgIEt2TG9hZGVyU2VydmljZS5zaG93KCk7XHJcbiAgICByZXR1cm4gc3JjLnBpcGUoZmluYWxpemUoKCkgPT4ge1xyXG4gICAgICBLdkxvYWRlclNlcnZpY2UuaGlkZSgpO1xyXG4gICAgfSkpO1xyXG4gIH07XHJcbn07XHJcbiJdfQ==
|