keevo-components 1.8.436 → 1.8.439

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.
@@ -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 = this.validFileTypes.some(type => event.target.files[0].type.startsWith(type));
26
+ const isValidFileType = validTypes.some(type => event.target.files[0].type.startsWith(type));
18
27
  if (!isValidFileType) {
19
- this.notificationService.toastError("Tipo de arquivo inválido");
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, use readAsArrayBuffer ou outro método apropriado
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
- return types;
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"]}
@@ -131,11 +131,11 @@ export class KvInputCalendarComponent extends BaseComponentInput {
131
131
  return dateMasked;
132
132
  }
133
133
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvInputCalendarComponent, deps: [{ token: i1.ComponentService }], target: i0.ɵɵFactoryTarget.Component }); }
134
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: KvInputCalendarComponent, selector: "kv-input-calendar", inputs: { isYear: "isYear", isMonthYear: "isMonthYear", minDate: "minDate", maxDate: "maxDate", showButtonBar: "showButtonBar", showIcon: "showIcon", showTime: "showTime", selectionMode: "selectionMode" }, outputs: { onSelectionChange: "onSelectionChange", onSelectionValue: "onSelectionValue" }, host: { listeners: { "window:resize": "onWindowResize($event)" } }, providers: ComponentProviders(KvInputCalendarComponent), viewQueries: [{ propertyName: "dateFilter", first: true, predicate: ["dateFilter"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<span>\r\n <kv-label\r\n [componentId]=\"componentId\"\r\n [label]=\"label && label + (showAsterisk ? '*' : '')\"\r\n />\r\n <p-calendar\r\n\r\n dateMask\r\n (onInput)=\"onKeyDate($event)\"\r\n\r\n #dateFilter\r\n appendTo=\"body\"\r\n [class]=\"baseInputClass\"\r\n [id]=\"componentId\"\r\n [(ngModel)]=\"value\"\r\n [disabled]=\"disabled\"\r\n [minDate]=\"minDate\"\r\n [maxDate]=\"maxDate\"\r\n [selectionMode]=\"selectionMode\"\r\n [showButtonBar]=\"showButtonBar\"\r\n [showIcon]=\"showIcon\"\r\n [showTime]=\"showTime\"\r\n [showOnFocus]=\"showTime || screenWidth > 1366 || selectionMode == 'range'\"\r\n [view]=\"typeView\"\r\n [dateFormat]=\"dateFormat\"\r\n (onBlur)=\"onInputBlur($event)\"\r\n (onClose)=\"onInputClose($event)\"\r\n (onSelect)=\"onInputChange($event)\"\r\n styleClass=\"inputs\"\r\n [placeholder]=\"placeholder\"\r\n >\r\n </p-calendar>\r\n\r\n <kv-error [hasError]=\"hasControlError()\">{{ erroMessage() }}</kv-error>\r\n</span>\r\n<ng-content></ng-content>\r\n", styles: ["::ng-deep .p-calendar-w-btn .p-datepicker-trigger{background-color:#f2f3f5;border:none;color:#000;border:solid 1px #d1d5db;width:1.875rem}::ng-deep .p-calendar-w-btn .p-datepicker-trigger:hover{background-color:#d9dadb}::ng-deep .p-calendar-w-btn .p-datepicker-trigger:disabled{background-color:#f2f3f5}::ng-deep .p-calendar-w-btn .p-datepicker-trigger:active{background-color:#c0c1c2}::ng-deep input{font-size:.875rem}\n", "@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";::ng-deep :root{--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter var,Inter,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter var,Inter,sans-serif!important}:host ::ng-deep .inputs{height:1.875rem}:host ::ng-deep .inputs,.p-inputtext,.p-inputtextarea{font-size:.875rem}::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}::ng-deep .p-dialog{min-width:320px}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-dialog .p-dialog-header .p-dialog-header-icon{display:none}::ng-deep .p-tooltip{font-size:.825rem!important}\n"], dependencies: [{ kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.KvErrorComponent, selector: "kv-error", inputs: ["formControl", "hasError"] }, { kind: "component", type: i4.KvLabelComponent, selector: "kv-label", inputs: ["componentId", "label"] }, { kind: "component", type: i5.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }] }); }
134
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: KvInputCalendarComponent, selector: "kv-input-calendar", inputs: { isYear: "isYear", isMonthYear: "isMonthYear", minDate: "minDate", maxDate: "maxDate", defaultDate: "defaultDate", showButtonBar: "showButtonBar", showIcon: "showIcon", showTime: "showTime", selectionMode: "selectionMode" }, outputs: { onSelectionChange: "onSelectionChange", onSelectionValue: "onSelectionValue" }, host: { listeners: { "window:resize": "onWindowResize($event)" } }, providers: ComponentProviders(KvInputCalendarComponent), viewQueries: [{ propertyName: "dateFilter", first: true, predicate: ["dateFilter"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<span>\r\n <kv-label\r\n [componentId]=\"componentId\"\r\n [label]=\"label && label + (showAsterisk ? '*' : '')\"\r\n />\r\n <p-calendar\r\n\r\n dateMask\r\n (onInput)=\"onKeyDate($event)\"\r\n\r\n #dateFilter\r\n appendTo=\"body\"\r\n [class]=\"baseInputClass\"\r\n [id]=\"componentId\"\r\n [(ngModel)]=\"value\"\r\n [disabled]=\"disabled\"\r\n [defaultDate]=\"defaultDate\"\r\n [minDate]=\"minDate\"\r\n [maxDate]=\"maxDate\"\r\n [selectionMode]=\"selectionMode\"\r\n [showButtonBar]=\"showButtonBar\"\r\n [showIcon]=\"showIcon\"\r\n [showTime]=\"showTime\"\r\n [showOnFocus]=\"showTime || screenWidth > 1366 || selectionMode == 'range'\"\r\n [view]=\"typeView\"\r\n [dateFormat]=\"dateFormat\"\r\n (onBlur)=\"onInputBlur($event)\"\r\n (onClose)=\"onInputClose($event)\"\r\n (onSelect)=\"onInputChange($event)\"\r\n styleClass=\"inputs\"\r\n [placeholder]=\"placeholder\"\r\n >\r\n </p-calendar>\r\n\r\n <kv-error [hasError]=\"hasControlError()\">{{ erroMessage() }}</kv-error>\r\n</span>\r\n<ng-content></ng-content>\r\n", styles: ["::ng-deep .p-calendar-w-btn .p-datepicker-trigger{background-color:#f2f3f5;border:none;color:#000;border:solid 1px #d1d5db;width:1.875rem}::ng-deep .p-calendar-w-btn .p-datepicker-trigger:hover{background-color:#d9dadb}::ng-deep .p-calendar-w-btn .p-datepicker-trigger:disabled{background-color:#f2f3f5}::ng-deep .p-calendar-w-btn .p-datepicker-trigger:active{background-color:#c0c1c2}::ng-deep input{font-size:.875rem}\n", "@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";::ng-deep :root{--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter var,Inter,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter var,Inter,sans-serif!important}:host ::ng-deep .inputs{height:1.875rem}:host ::ng-deep .inputs,.p-inputtext,.p-inputtextarea{font-size:.875rem}::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}::ng-deep .p-dialog{min-width:320px}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-dialog .p-dialog-header .p-dialog-header-icon{display:none}::ng-deep .p-tooltip{font-size:.825rem!important}\n"], dependencies: [{ kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.KvErrorComponent, selector: "kv-error", inputs: ["formControl", "hasError"] }, { kind: "component", type: i4.KvLabelComponent, selector: "kv-label", inputs: ["componentId", "label"] }, { kind: "component", type: i5.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }] }); }
135
135
  }
136
136
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvInputCalendarComponent, decorators: [{
137
137
  type: Component,
138
- args: [{ selector: 'kv-input-calendar', providers: ComponentProviders(KvInputCalendarComponent), template: "<span>\r\n <kv-label\r\n [componentId]=\"componentId\"\r\n [label]=\"label && label + (showAsterisk ? '*' : '')\"\r\n />\r\n <p-calendar\r\n\r\n dateMask\r\n (onInput)=\"onKeyDate($event)\"\r\n\r\n #dateFilter\r\n appendTo=\"body\"\r\n [class]=\"baseInputClass\"\r\n [id]=\"componentId\"\r\n [(ngModel)]=\"value\"\r\n [disabled]=\"disabled\"\r\n [minDate]=\"minDate\"\r\n [maxDate]=\"maxDate\"\r\n [selectionMode]=\"selectionMode\"\r\n [showButtonBar]=\"showButtonBar\"\r\n [showIcon]=\"showIcon\"\r\n [showTime]=\"showTime\"\r\n [showOnFocus]=\"showTime || screenWidth > 1366 || selectionMode == 'range'\"\r\n [view]=\"typeView\"\r\n [dateFormat]=\"dateFormat\"\r\n (onBlur)=\"onInputBlur($event)\"\r\n (onClose)=\"onInputClose($event)\"\r\n (onSelect)=\"onInputChange($event)\"\r\n styleClass=\"inputs\"\r\n [placeholder]=\"placeholder\"\r\n >\r\n </p-calendar>\r\n\r\n <kv-error [hasError]=\"hasControlError()\">{{ erroMessage() }}</kv-error>\r\n</span>\r\n<ng-content></ng-content>\r\n", styles: ["::ng-deep .p-calendar-w-btn .p-datepicker-trigger{background-color:#f2f3f5;border:none;color:#000;border:solid 1px #d1d5db;width:1.875rem}::ng-deep .p-calendar-w-btn .p-datepicker-trigger:hover{background-color:#d9dadb}::ng-deep .p-calendar-w-btn .p-datepicker-trigger:disabled{background-color:#f2f3f5}::ng-deep .p-calendar-w-btn .p-datepicker-trigger:active{background-color:#c0c1c2}::ng-deep input{font-size:.875rem}\n", "@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";::ng-deep :root{--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter var,Inter,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter var,Inter,sans-serif!important}:host ::ng-deep .inputs{height:1.875rem}:host ::ng-deep .inputs,.p-inputtext,.p-inputtextarea{font-size:.875rem}::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}::ng-deep .p-dialog{min-width:320px}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-dialog .p-dialog-header .p-dialog-header-icon{display:none}::ng-deep .p-tooltip{font-size:.825rem!important}\n"] }]
138
+ args: [{ selector: 'kv-input-calendar', providers: ComponentProviders(KvInputCalendarComponent), template: "<span>\r\n <kv-label\r\n [componentId]=\"componentId\"\r\n [label]=\"label && label + (showAsterisk ? '*' : '')\"\r\n />\r\n <p-calendar\r\n\r\n dateMask\r\n (onInput)=\"onKeyDate($event)\"\r\n\r\n #dateFilter\r\n appendTo=\"body\"\r\n [class]=\"baseInputClass\"\r\n [id]=\"componentId\"\r\n [(ngModel)]=\"value\"\r\n [disabled]=\"disabled\"\r\n [defaultDate]=\"defaultDate\"\r\n [minDate]=\"minDate\"\r\n [maxDate]=\"maxDate\"\r\n [selectionMode]=\"selectionMode\"\r\n [showButtonBar]=\"showButtonBar\"\r\n [showIcon]=\"showIcon\"\r\n [showTime]=\"showTime\"\r\n [showOnFocus]=\"showTime || screenWidth > 1366 || selectionMode == 'range'\"\r\n [view]=\"typeView\"\r\n [dateFormat]=\"dateFormat\"\r\n (onBlur)=\"onInputBlur($event)\"\r\n (onClose)=\"onInputClose($event)\"\r\n (onSelect)=\"onInputChange($event)\"\r\n styleClass=\"inputs\"\r\n [placeholder]=\"placeholder\"\r\n >\r\n </p-calendar>\r\n\r\n <kv-error [hasError]=\"hasControlError()\">{{ erroMessage() }}</kv-error>\r\n</span>\r\n<ng-content></ng-content>\r\n", styles: ["::ng-deep .p-calendar-w-btn .p-datepicker-trigger{background-color:#f2f3f5;border:none;color:#000;border:solid 1px #d1d5db;width:1.875rem}::ng-deep .p-calendar-w-btn .p-datepicker-trigger:hover{background-color:#d9dadb}::ng-deep .p-calendar-w-btn .p-datepicker-trigger:disabled{background-color:#f2f3f5}::ng-deep .p-calendar-w-btn .p-datepicker-trigger:active{background-color:#c0c1c2}::ng-deep input{font-size:.875rem}\n", "@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";::ng-deep :root{--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter var,Inter,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter var,Inter,sans-serif!important}:host ::ng-deep .inputs{height:1.875rem}:host ::ng-deep .inputs,.p-inputtext,.p-inputtextarea{font-size:.875rem}::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}::ng-deep .p-dialog{min-width:320px}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-dialog .p-dialog-header .p-dialog-header-icon{display:none}::ng-deep .p-tooltip{font-size:.825rem!important}\n"] }]
139
139
  }], ctorParameters: () => [{ type: i1.ComponentService }], propDecorators: { isYear: [{
140
140
  type: Input
141
141
  }], isMonthYear: [{
@@ -144,6 +144,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
144
144
  type: Input
145
145
  }], maxDate: [{
146
146
  type: Input
147
+ }], defaultDate: [{
148
+ type: Input
147
149
  }], showButtonBar: [{
148
150
  type: Input
149
151
  }], showIcon: [{
@@ -163,4 +165,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
163
165
  type: HostListener,
164
166
  args: ['window:resize', ['$event']]
165
167
  }] } });
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-input-calendar.component.js","sourceRoot":"","sources":["../../../../../../../projects/keevo-components/src/lib/components/kv-inputs/kv-input-calendar/kv-input-calendar.component.ts","../../../../../../../projects/keevo-components/src/lib/components/kv-inputs/kv-input-calendar/kv-input-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { CalendarTypeView } from 'primeng/calendar';\r\n\r\nimport { BaseComponentInput } from '../../../api/base-components/base-component-input';\r\nimport { ComponentProviders } from '../../../api/helpers/component-providers';\r\nimport { ComponentService } from '../../../api/services/component.service';\r\n\r\n@Component({\r\n  selector: 'kv-input-calendar',\r\n  templateUrl: './kv-input-calendar.component.html',\r\n  styleUrls: [\r\n    './kv-input-calendar.component.scss',\r\n    '../../keevo-components-styles.scss',\r\n  ],\r\n  providers: ComponentProviders(KvInputCalendarComponent),\r\n})\r\nexport class KvInputCalendarComponent\r\n  extends BaseComponentInput<Date>\r\n  implements OnInit\r\n{\r\n  @Input() isYear: boolean = false;\r\n  @Input() isMonthYear: boolean = false;\r\n\r\n  @Input() minDate!: Date;\r\n  @Input() maxDate!: Date;\r\n\r\n  @Input() showButtonBar: boolean = false;\r\n  @Input() showIcon: boolean = true;\r\n  @Input() showTime: boolean = false;\r\n  @Input() selectionMode: 'single' | 'multiple' | 'range' = 'single';\r\n  \r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionValue: EventEmitter<any> = new EventEmitter();\r\n  \r\n  @ViewChild('dateFilter') private dateFilter: any;\r\n\r\n  typeView: CalendarTypeView = 'date';\r\n  dateFormat: string = 'dd/mm/yy';\r\n\r\n  screenWidth!: number;\r\n\r\n  constructor(componentService: ComponentService) {\r\n    super(componentService);\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.screenWidth = window.innerWidth;\r\n  }\r\n\r\n  override writeValue(value: Date): void {\r\n    this.value = value;\r\n\r\n    if (value && typeof value === 'string') {\r\n      this.value = new Date(value);\r\n    }\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n\r\n    if (this.isYear) {\r\n      this.typeView = 'year';\r\n      this.dateFormat = 'yy';\r\n    } else if (this.isMonthYear) {\r\n      this.typeView = 'month';\r\n      this.dateFormat = 'mm/yy';\r\n    } else {\r\n      this.typeView = 'date';\r\n      this.dateFormat = 'dd/mm/yy';\r\n    }\r\n\r\n    this.screenWidth = window.innerWidth;\r\n  }\r\n\r\n  protected onInputChange(event: any) {\r\n    this.hideOnRangeMode();\r\n    this.onSelectionValue.emit(event);\r\n\r\n    if (this.formControl) {\r\n      this.onSelectionChange.emit(this.formControl.value);\r\n    }\r\n  }\r\n\r\n  hideOnRangeMode() {\r\n    if (this.selectionMode == 'range') {\r\n      if (this.dateFilter.value[1]) {\r\n        this.dateFilter.hideOverlay();\r\n      }\r\n    }\r\n  }\r\n\r\n  lastInputValue: string = '';\r\n  onKeyDate(event: any) {\r\n    if (this.typeView === 'date') {\r\n\r\n      const inputElement = event.target;\r\n\r\n      let inputValue = inputElement.value.replace(/\\D/g, ''); // Remove tudo que não seja dígito\r\n\r\n      const cursorPosition = inputElement.selectionStart; // Pega a posição atual do cursor\r\n\r\n      // Limita a entrada a 8 caracteres (ddmmyyyy)\r\n      if (inputValue.length > 8) {\r\n        inputValue = inputValue.substring(0, 8);\r\n      }\r\n\r\n      inputValue = this.maskDate(inputValue);\r\n      let indAdicao =\r\n        inputValue.length > this.lastInputValue.length ? true : false;\r\n\r\n      this.lastInputValue = inputValue;\r\n\r\n      // Calcula a diferença de tamanho após aplicar a máscara\r\n      const maskedLength = inputValue.length;\r\n      const lengthDiff = maskedLength - this.lastInputValue.length;\r\n\r\n      // Atualiza o valor do input sem perder a posição do cursor\r\n      inputElement.value = inputValue;\r\n\r\n      // Ajusta a posição do cursor de acordo com a mudança causada pela máscara\r\n      let newCursorPosition = cursorPosition + lengthDiff;\r\n\r\n      // Se o cursor estava exatamente em uma posição de barra e foi uma adição, ajusta para pular a barra ( somente na adição de caracteres )\r\n      if (indAdicao) {\r\n        if (cursorPosition === 3 || cursorPosition === 6) {\r\n          newCursorPosition += 1;\r\n        }\r\n      }\r\n      // Evita que o cursor vá além do final do valor digitado\r\n      if (newCursorPosition > inputElement.value.length) {\r\n        newCursorPosition = inputElement.value.length;\r\n      }\r\n\r\n      // Define a nova posição do cursor\r\n      inputElement.setSelectionRange(newCursorPosition, newCursorPosition);\r\n    }\r\n  }\r\n\r\n  override onInputBlur(event: Event): void {\r\n    super.onInputBlur(event);\r\n    \r\n    if (this.typeView === 'date') {\r\n      const input = event.target as HTMLInputElement; // Cast para HTMLInputElement\r\n      if (input && input.value) {\r\n        const dateString = input.value; // Pega o valor do input\r\n        const [day, month, year] = dateString.split('/');\r\n\r\n\r\n        // Verifica se é uma data válida\r\n        if (\r\n          day &&\r\n          month &&\r\n          year &&\r\n          day.length === 2 &&\r\n          month.length === 2 &&\r\n          year.length === 4\r\n        ) {\r\n\r\n          const objDate = new Date(+year, +month - 1, +day);\r\n\r\n          if ((!isNaN(objDate.getTime())) && !(+month > 12 || +day > 31)) {\r\n            this.dateFilter.value = objDate; // Atribui a data sem barras ao dateFilter\r\n          }else{\r\n            this.formControl?.setErrors({ invalidDate: true, erroMessage: 'Data Invalida!' });\r\n          }\r\n        }\r\n\r\n\r\n        \r\n\r\n\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  maskDate(date: string): string {\r\n    // Aplica a máscara (dd/mm/yyyy)\r\n    let dateMasked = date;\r\n    if (date.length >= 5) {\r\n      dateMasked = date.replace(/^(\\d{2})(\\d{2})(\\d{0,4})/, '$1/$2/$3'); // Formata como dd/mm/yyyy\r\n    } else if (date.length >= 3) {\r\n      dateMasked = date.replace(/^(\\d{2})(\\d{0,2})/, '$1/$2'); // Formata como dd/mm\r\n    }\r\n    return dateMasked;\r\n  }\r\n}\r\n","<span>\r\n  <kv-label\r\n    [componentId]=\"componentId\"\r\n    [label]=\"label && label + (showAsterisk ? '*' : '')\"\r\n  />\r\n  <p-calendar\r\n\r\n    dateMask\r\n    (onInput)=\"onKeyDate($event)\"\r\n\r\n    #dateFilter\r\n    appendTo=\"body\"\r\n    [class]=\"baseInputClass\"\r\n    [id]=\"componentId\"\r\n    [(ngModel)]=\"value\"\r\n    [disabled]=\"disabled\"\r\n    [minDate]=\"minDate\"\r\n    [maxDate]=\"maxDate\"\r\n    [selectionMode]=\"selectionMode\"\r\n    [showButtonBar]=\"showButtonBar\"\r\n    [showIcon]=\"showIcon\"\r\n    [showTime]=\"showTime\"\r\n    [showOnFocus]=\"showTime || screenWidth > 1366 || selectionMode == 'range'\"\r\n    [view]=\"typeView\"\r\n    [dateFormat]=\"dateFormat\"\r\n    (onBlur)=\"onInputBlur($event)\"\r\n    (onClose)=\"onInputClose($event)\"\r\n    (onSelect)=\"onInputChange($event)\"\r\n    styleClass=\"inputs\"\r\n    [placeholder]=\"placeholder\"\r\n  >\r\n  </p-calendar>\r\n\r\n  <kv-error [hasError]=\"hasControlError()\">{{ erroMessage() }}</kv-error>\r\n</span>\r\n<ng-content></ng-content>\r\n"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-input-calendar.component.js","sourceRoot":"","sources":["../../../../../../../projects/keevo-components/src/lib/components/kv-inputs/kv-input-calendar/kv-input-calendar.component.ts","../../../../../../../projects/keevo-components/src/lib/components/kv-inputs/kv-input-calendar/kv-input-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { CalendarTypeView } from 'primeng/calendar';\r\n\r\nimport { BaseComponentInput } from '../../../api/base-components/base-component-input';\r\nimport { ComponentProviders } from '../../../api/helpers/component-providers';\r\nimport { ComponentService } from '../../../api/services/component.service';\r\n\r\n@Component({\r\n  selector: 'kv-input-calendar',\r\n  templateUrl: './kv-input-calendar.component.html',\r\n  styleUrls: [\r\n    './kv-input-calendar.component.scss',\r\n    '../../keevo-components-styles.scss',\r\n  ],\r\n  providers: ComponentProviders(KvInputCalendarComponent),\r\n})\r\nexport class KvInputCalendarComponent\r\n  extends BaseComponentInput<Date>\r\n  implements OnInit\r\n{\r\n  @Input() isYear: boolean = false;\r\n  @Input() isMonthYear: boolean = false;\r\n\r\n  @Input() minDate!: Date;\r\n  @Input() maxDate!: Date;\r\n  @Input() defaultDate!: Date;\r\n\r\n  @Input() showButtonBar: boolean = false;\r\n  @Input() showIcon: boolean = true;\r\n  @Input() showTime: boolean = false;\r\n  @Input() selectionMode: 'single' | 'multiple' | 'range' = 'single';\r\n  \r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionValue: EventEmitter<any> = new EventEmitter();\r\n  \r\n  @ViewChild('dateFilter') private dateFilter: any;\r\n\r\n  typeView: CalendarTypeView = 'date';\r\n  dateFormat: string = 'dd/mm/yy';\r\n\r\n  screenWidth!: number;\r\n\r\n  constructor(componentService: ComponentService) {\r\n    super(componentService);\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.screenWidth = window.innerWidth;\r\n  }\r\n\r\n  override writeValue(value: Date): void {\r\n    this.value = value;\r\n\r\n    if (value && typeof value === 'string') {\r\n      this.value = new Date(value);\r\n    }\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n\r\n    if (this.isYear) {\r\n      this.typeView = 'year';\r\n      this.dateFormat = 'yy';\r\n    } else if (this.isMonthYear) {\r\n      this.typeView = 'month';\r\n      this.dateFormat = 'mm/yy';\r\n    } else {\r\n      this.typeView = 'date';\r\n      this.dateFormat = 'dd/mm/yy';\r\n    }\r\n    this.screenWidth = window.innerWidth;\r\n  }\r\n\r\n  protected onInputChange(event: any) {\r\n    this.hideOnRangeMode();\r\n    this.onSelectionValue.emit(event);\r\n\r\n    if (this.formControl) {\r\n      this.onSelectionChange.emit(this.formControl.value);\r\n    }\r\n  }\r\n\r\n  hideOnRangeMode() {\r\n    if (this.selectionMode == 'range') {\r\n      if (this.dateFilter.value[1]) {\r\n        this.dateFilter.hideOverlay();\r\n      }\r\n    }\r\n  }\r\n\r\n  lastInputValue: string = '';\r\n  onKeyDate(event: any) {\r\n    if (this.typeView === 'date') {\r\n\r\n      const inputElement = event.target;\r\n\r\n      let inputValue = inputElement.value.replace(/\\D/g, ''); // Remove tudo que não seja dígito\r\n\r\n      const cursorPosition = inputElement.selectionStart; // Pega a posição atual do cursor\r\n\r\n      // Limita a entrada a 8 caracteres (ddmmyyyy)\r\n      if (inputValue.length > 8) {\r\n        inputValue = inputValue.substring(0, 8);\r\n      }\r\n\r\n      inputValue = this.maskDate(inputValue);\r\n      let indAdicao =\r\n        inputValue.length > this.lastInputValue.length ? true : false;\r\n\r\n      this.lastInputValue = inputValue;\r\n\r\n      // Calcula a diferença de tamanho após aplicar a máscara\r\n      const maskedLength = inputValue.length;\r\n      const lengthDiff = maskedLength - this.lastInputValue.length;\r\n\r\n      // Atualiza o valor do input sem perder a posição do cursor\r\n      inputElement.value = inputValue;\r\n\r\n      // Ajusta a posição do cursor de acordo com a mudança causada pela máscara\r\n      let newCursorPosition = cursorPosition + lengthDiff;\r\n\r\n      // Se o cursor estava exatamente em uma posição de barra e foi uma adição, ajusta para pular a barra ( somente na adição de caracteres )\r\n      if (indAdicao) {\r\n        if (cursorPosition === 3 || cursorPosition === 6) {\r\n          newCursorPosition += 1;\r\n        }\r\n      }\r\n      // Evita que o cursor vá além do final do valor digitado\r\n      if (newCursorPosition > inputElement.value.length) {\r\n        newCursorPosition = inputElement.value.length;\r\n      }\r\n\r\n      // Define a nova posição do cursor\r\n      inputElement.setSelectionRange(newCursorPosition, newCursorPosition);\r\n    }\r\n  }\r\n\r\n  override onInputBlur(event: Event): void {\r\n    super.onInputBlur(event);\r\n    \r\n    if (this.typeView === 'date') {\r\n      const input = event.target as HTMLInputElement; // Cast para HTMLInputElement\r\n      if (input && input.value) {\r\n        const dateString = input.value; // Pega o valor do input\r\n        const [day, month, year] = dateString.split('/');\r\n\r\n\r\n        // Verifica se é uma data válida\r\n        if (\r\n          day &&\r\n          month &&\r\n          year &&\r\n          day.length === 2 &&\r\n          month.length === 2 &&\r\n          year.length === 4\r\n        ) {\r\n\r\n          const objDate = new Date(+year, +month - 1, +day);\r\n\r\n          if ((!isNaN(objDate.getTime())) && !(+month > 12 || +day > 31)) {\r\n            this.dateFilter.value = objDate; // Atribui a data sem barras ao dateFilter\r\n          }else{\r\n            this.formControl?.setErrors({ invalidDate: true, erroMessage: 'Data Invalida!' });\r\n          }\r\n        }\r\n\r\n\r\n        \r\n\r\n\r\n      }\r\n    }\r\n\r\n  }\r\n\r\n  maskDate(date: string): string {\r\n    // Aplica a máscara (dd/mm/yyyy)\r\n    let dateMasked = date;\r\n    if (date.length >= 5) {\r\n      dateMasked = date.replace(/^(\\d{2})(\\d{2})(\\d{0,4})/, '$1/$2/$3'); // Formata como dd/mm/yyyy\r\n    } else if (date.length >= 3) {\r\n      dateMasked = date.replace(/^(\\d{2})(\\d{0,2})/, '$1/$2'); // Formata como dd/mm\r\n    }\r\n    return dateMasked;\r\n  }\r\n}\r\n","<span>\r\n  <kv-label\r\n    [componentId]=\"componentId\"\r\n    [label]=\"label && label + (showAsterisk ? '*' : '')\"\r\n  />\r\n  <p-calendar\r\n\r\n    dateMask\r\n    (onInput)=\"onKeyDate($event)\"\r\n\r\n    #dateFilter\r\n    appendTo=\"body\"\r\n    [class]=\"baseInputClass\"\r\n    [id]=\"componentId\"\r\n    [(ngModel)]=\"value\"\r\n    [disabled]=\"disabled\"\r\n    [defaultDate]=\"defaultDate\"\r\n    [minDate]=\"minDate\"\r\n    [maxDate]=\"maxDate\"\r\n    [selectionMode]=\"selectionMode\"\r\n    [showButtonBar]=\"showButtonBar\"\r\n    [showIcon]=\"showIcon\"\r\n    [showTime]=\"showTime\"\r\n    [showOnFocus]=\"showTime || screenWidth > 1366 || selectionMode == 'range'\"\r\n    [view]=\"typeView\"\r\n    [dateFormat]=\"dateFormat\"\r\n    (onBlur)=\"onInputBlur($event)\"\r\n    (onClose)=\"onInputClose($event)\"\r\n    (onSelect)=\"onInputChange($event)\"\r\n    styleClass=\"inputs\"\r\n    [placeholder]=\"placeholder\"\r\n  >\r\n  </p-calendar>\r\n\r\n  <kv-error [hasError]=\"hasControlError()\">{{ erroMessage() }}</kv-error>\r\n</span>\r\n<ng-content></ng-content>\r\n"]}