keevo-components 1.8.232 → 1.8.234

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.
@@ -0,0 +1,118 @@
1
+ import { Component, Input, Output, EventEmitter, ViewChild } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../../api/services/notification.service";
4
+ import * as i2 from "@angular/common";
5
+ export class KvFileUploadComponent {
6
+ constructor(notificationService) {
7
+ this.notificationService = notificationService;
8
+ this.widthComponent = '400px';
9
+ this.heightComponent = 'auto';
10
+ this.validFileTypes = ['image/', 'application/pdf', 'text/html'];
11
+ this.fileEmit = new EventEmitter();
12
+ }
13
+ onFileSelected(event) {
14
+ if (event.target.files.length == 0)
15
+ return;
16
+ const isValidFileType = this.validFileTypes.some(type => event.target.files[0].type.startsWith(type));
17
+ if (!isValidFileType) {
18
+ this.notificationService.toastError("Tipo de arquivo inválido");
19
+ this.formGroup.controls[this.formControlName].setValue(null);
20
+ return;
21
+ }
22
+ this.formGroup.controls[this.formControlName].setValue(event.target.files[0]);
23
+ }
24
+ deleteFile() {
25
+ this.formGroup.controls[this.formControlName].setValue(null);
26
+ this.fileInput.nativeElement.value = '';
27
+ }
28
+ formatBytes(bytes, decimals = 2) {
29
+ if (!bytes) {
30
+ return "0 Bytes";
31
+ }
32
+ const k = 1024;
33
+ const dm = decimals <= 0 ? 0 : decimals;
34
+ const sizes = ["Bytes", "KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"];
35
+ const i = Math.floor(Math.log(bytes) / Math.log(k));
36
+ return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + " " + sizes[i];
37
+ }
38
+ addDragOverClass(event) {
39
+ const container = event.target;
40
+ container.classList.add('dragover');
41
+ }
42
+ removeDragOverClass(event) {
43
+ const container = event.target;
44
+ container.classList.remove('dragover');
45
+ }
46
+ handleFile(file) {
47
+ const isValidFileType = this.validFileTypes.some(type => file.type.startsWith(type));
48
+ if (!isValidFileType) {
49
+ this.notificationService.toastError('Tipo de arquivo inválido');
50
+ this.formGroup.controls[this.formControlName].setValue(null);
51
+ return;
52
+ }
53
+ this.formGroup.controls[this.formControlName].setValue(file);
54
+ const reader = new FileReader();
55
+ if (file.type.startsWith('image/'))
56
+ reader.readAsDataURL(file);
57
+ else
58
+ reader.readAsArrayBuffer(file); // Para outros tipos de arquivo, use readAsArrayBuffer ou outro método apropriado
59
+ this.fileEmit.emit(file);
60
+ }
61
+ onDragOver(event) {
62
+ event.preventDefault();
63
+ event.stopPropagation();
64
+ this.addDragOverClass(event);
65
+ }
66
+ onDragLeave(event) {
67
+ event.preventDefault();
68
+ event.stopPropagation();
69
+ this.removeDragOverClass(event);
70
+ }
71
+ onDrop(event) {
72
+ event.preventDefault();
73
+ event.stopPropagation();
74
+ this.removeDragOverClass(event);
75
+ if (event.dataTransfer && event.dataTransfer.files.length > 0) {
76
+ this.handleFile(event.dataTransfer.files[0]);
77
+ }
78
+ }
79
+ setAccept() {
80
+ let types = '';
81
+ this.validFileTypes.forEach(type => {
82
+ if (type.includes('image'))
83
+ types += '.jpg, .png, .bmp';
84
+ if (type.includes('html'))
85
+ types += '.html';
86
+ if (type.includes('pdf'))
87
+ types += '.pdf';
88
+ });
89
+ return types;
90
+ }
91
+ 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 }); }
92
+ 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" }, 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"] }] }); }
93
+ }
94
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvFileUploadComponent, decorators: [{
95
+ type: Component,
96
+ args: [{ selector: 'kv-file-upload', 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"] }]
97
+ }], ctorParameters: () => [{ type: i1.NotificationService }], propDecorators: { formGroup: [{
98
+ type: Input
99
+ }], formControlName: [{
100
+ type: Input
101
+ }], widthComponent: [{
102
+ type: Input
103
+ }], heightComponent: [{
104
+ type: Input
105
+ }], description: [{
106
+ type: Input
107
+ }], validFileTypes: [{
108
+ type: Input
109
+ }], fileEmit: [{
110
+ type: Output
111
+ }], fileInput: [{
112
+ type: ViewChild,
113
+ args: ['fileInput']
114
+ }], inputUpload: [{
115
+ type: ViewChild,
116
+ args: ['inputUpload']
117
+ }] } });
118
+ //# 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\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  }\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"]}
@@ -0,0 +1,18 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { KvFileUploadComponent } from './kv-file-upload.component';
4
+ import * as i0 from "@angular/core";
5
+ export class KvFileUploadModule {
6
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvFileUploadModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.8", ngImport: i0, type: KvFileUploadModule, declarations: [KvFileUploadComponent], imports: [CommonModule], exports: [KvFileUploadComponent] }); }
8
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvFileUploadModule, imports: [CommonModule] }); }
9
+ }
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvFileUploadModule, decorators: [{
11
+ type: NgModule,
12
+ args: [{
13
+ declarations: [KvFileUploadComponent],
14
+ imports: [CommonModule],
15
+ exports: [KvFileUploadComponent]
16
+ }]
17
+ }] });
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtZmlsZS11cGxvYWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtZmlsZS11cGxvYWQva3YtZmlsZS11cGxvYWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQU9uRSxNQUFNLE9BQU8sa0JBQWtCOzhHQUFsQixrQkFBa0I7K0dBQWxCLGtCQUFrQixpQkFKZCxxQkFBcUIsYUFDMUIsWUFBWSxhQUNaLHFCQUFxQjsrR0FFcEIsa0JBQWtCLFlBSG5CLFlBQVk7OzJGQUdYLGtCQUFrQjtrQkFMOUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztvQkFDckMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztpQkFDakMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBLdkZpbGVVcGxvYWRDb21wb25lbnQgfSBmcm9tICcuL2t2LWZpbGUtdXBsb2FkLmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW0t2RmlsZVVwbG9hZENvbXBvbmVudF0sXHJcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXHJcbiAgZXhwb3J0czogW0t2RmlsZVVwbG9hZENvbXBvbmVudF1cclxufSlcclxuZXhwb3J0IGNsYXNzIEt2RmlsZVVwbG9hZE1vZHVsZSB7IH1cclxuIl19