keevo-components 2.0.238 → 2.0.240

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.
@@ -59,6 +59,7 @@ export class KvFileUploadComponent {
59
59
  if (!isValidFileType) {
60
60
  this.notificationService.toastError('Tipo de arquivo inválido');
61
61
  this.formGroup.controls[this.formControlName].setValue(null);
62
+ event.target.value = '';
62
63
  return;
63
64
  }
64
65
  this.formGroup.controls[this.formControlName].setValue(event.target.files[0]);
@@ -188,4 +189,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
188
189
  type: ViewChild,
189
190
  args: ['inputUpload']
190
191
  }] } });
191
- //# 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, input, computed, signal } 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', 'text/xml', 'application/xml', 'text/plain'];\r\n  @Input() tamanhoMaximoPermitido: string = '';\r\n  @Input() includeOfficeTypes: boolean = false; // Propriedade para controlar os tipos de Office\r\n\r\n  maxSizeFile = input<number>(10)\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      (type === 'application/xml' && event.target.files[0].type === 'application/xml') ||\r\n      (type === 'text/xml' && event.target.files[0].type === 'text/xml')\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    this.fileEmit.emit(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  // returnMbSize = computed(() => (bytes: any) => {\r\n  //   if (bytes === null || bytes === undefined) {\r\n  //     return '0 MB';\r\n  //   }\r\n\r\n  //   const mbSize = bytes / (1024 * 1024);\r\n    \r\n  //   return this.formatBytes(mbSize, 2);\r\n  // });\r\n\r\n  progressValue = computed(() => (bytes: any) => {\r\n    if (bytes === null || bytes === undefined) {\r\n      return 0;\r\n    }\r\n\r\n    const mbSize = bytes / (1024 * 1024);\r\n    let progressValue = (Number(mbSize) / this.maxSizeFile()) * 100;\r\n\r\n    // Limita o valor do progresso entre 0 e 100\r\n    return Math.min(Math.max(progressValue, 0), 100);\r\n  });\r\n\r\n  returnProgressLabel = computed(() => (bytes: any) => {\r\n    if (bytes === null || bytes === undefined) {\r\n      return '0 MB';\r\n    }\r\n\r\n    const mbSize = bytes / (1024 * 1024);\r\n    // let progressValue = (Number(mbSize) / this.maxSizeFile()) * 100;\r\n    // this.progressValue.set(progressValue);\r\n    // this.progressValue.set((mbSize / this.maxSizeFile())*100);\r\n    return `${mbSize.toFixed(2)}/${this.maxSizeFile()} MB`;\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    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 =>\r\n      file.type.startsWith(type) ||\r\n      file.type === 'application/xml' ||\r\n      file.type === 'text/xml'\r\n    );\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 if (file.type === 'application/xml' || file.type === 'text/xml') {\r\n      reader.readAsText(file);\r\n    } else {\r\n      reader.readAsArrayBuffer(file);\r\n    }\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      if (type.includes('xml')) types += '.xml, ';\r\n      if (type.includes('plain')) types += '.txt, ';\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]=\"{\r\n    'invalid-border':\r\n      formGroup &&\r\n      formControlName &&\r\n      formGroup.controls[formControlName].invalid &&\r\n      formGroup.controls[formControlName].touched\r\n  }\"\r\n  class=\"border-dashed border-2 border-round-lg border-gray-400 flex justify-content-end relative p-2\"\r\n  (dragover)=\"onDragOver($event)\"\r\n  (dragleave)=\"onDragLeave($event)\"\r\n  (drop)=\"onDrop($event)\"\r\n  [style.minWidth]=\"'20rem'\"\r\n  [style.minHeight]=\"'10rem'\"\r\n  [style.width]=\"widthComponent\"\r\n  [style.height]=\"heightComponent\"\r\n>\r\n  @if(formGroup && formControlName && formGroup.controls[formControlName].value)\r\n  {\r\n  <button\r\n    style=\"background-color: transparent\"\r\n    pButton\r\n    (click)=\"deleteFile()\"\r\n    class=\"absolute transition-colors transition-duration-500 text-red-700 hover:text-red-500 m-1 h-2rem w-2rem\"\r\n    [text]=\"true\"\r\n    [icon]=\"'pi pi-trash'\"\r\n  ></button>\r\n  }\r\n  <div\r\n    class=\"col-12 flex flex-column align-items-center justify-content-center\"\r\n  >\r\n    <div\r\n      class=\"w-full align-items-center justify-content-center col-12\"\r\n      style=\"cursor: pointer\"\r\n      [style.display]=\"formGroup.controls[formControlName].value ? 'none' : 'flex'\"\r\n      (click)=\"fileInput.click()\"\r\n    >\r\n      <input\r\n        type=\"file\"\r\n        (change)=\"onFileSelected($event)\"\r\n        #fileInput\r\n        [accept]=\"setAccept()\"\r\n        hidden\r\n      />\r\n\r\n      @if(formGroup && formControlName &&\r\n      !formGroup.controls[formControlName].value) {\r\n      <div class=\"flex flex-column align-items-center justify-content-center\">\r\n        <!-- @if(tamanhoMaximoPermitido) {\r\n            <p class=\"w-full text-start\">Tamanho maximo permitido ( {{tamanhoMaximoPermitido}} )*</p>\r\n          } -->\r\n        <span\r\n          class=\"material-symbols-outlined mt-2 text-gray-700\"\r\n          style=\"font-size: 2.5rem\"\r\n        >\r\n          cloud_upload\r\n        </span>\r\n\r\n        @if(description) {\r\n        <span class=\"font-medium text-center text-sm text-gray-600\">\r\n          {{ description }}\r\n        </span>\r\n        } @else {\r\n        <span class=\"font-medium text-center text-sm text-gray-600\">\r\n          Arraste e solte o arquivo aqui, ou<br />clique para selecioná-lo\r\n        </span>\r\n        }\r\n      </div>\r\n\r\n      }\r\n    </div>\r\n\r\n    @if(formGroup && formControlName && formGroup.controls[formControlName].value) {\r\n    <div class=\"flex flex-column justify-content-between h-full w-full\">\r\n      <div class=\"col-9 p-0 pt-1\">\r\n        <kv-progress-bar\r\n          [value]=\"\r\n            progressValue()(formGroup.controls[formControlName].value?.size)\r\n          \"\r\n          [showValue]=\"false\"\r\n          [barStyleClass]=\"\r\n            progressValue()(formGroup.controls[formControlName].value?.size) ==\r\n            100\r\n              ? 'bg-red-400'\r\n              : ''\r\n          \"\r\n          [label]=\"\r\n            returnProgressLabel()(\r\n              formGroup.controls[formControlName].value?.size\r\n            )\r\n          \"\r\n        ></kv-progress-bar>\r\n\r\n        @if(progressValue()(formGroup.controls[formControlName].value?.size) ==\r\n        100) {\r\n        <span class=\"text-red-600 text-xs\">Tamanho máximo excedido.</span>\r\n        }\r\n      </div>\r\n\r\n      <div class=\"flex flex-column gap-2\">\r\n        <span class=\"font-medium text-gray-600 text-xs\"\r\n          >Arquivo Selecionado:</span\r\n        >\r\n\r\n        <div class=\"flex flex-row justify-content-between\">\r\n          <span class=\"text-gray-600 text-xs\">{{\r\n            formGroup.controls[formControlName].value?.name\r\n          }}</span>\r\n          <span\r\n            class=\"\r\n          {{\r\n              progressValue()(\r\n                formGroup.controls[formControlName].value?.size\r\n              ) == 100\r\n                ? 'text-red-600'\r\n                : 'text-green-600'\r\n            }} \r\n           text-xs\"\r\n            >{{\r\n              formatBytes(formGroup.controls[formControlName].value?.size)\r\n            }}</span\r\n          >\r\n        </div>\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\r\n&& formGroup.controls[formControlName].touched) {\r\n<p class=\"error-message\">Campo obrigatório</p>\r\n}\r\n"]}
192
+ //# 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, input, computed, signal } 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', 'text/xml', 'application/xml', 'text/plain'];\r\n  @Input() tamanhoMaximoPermitido: string = '';\r\n  @Input() includeOfficeTypes: boolean = false; // Propriedade para controlar os tipos de Office\r\n\r\n  maxSizeFile = input<number>(10)\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      (type === 'application/xml' && event.target.files[0].type === 'application/xml') ||\r\n      (type === 'text/xml' && event.target.files[0].type === 'text/xml')\r\n    );\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      \r\n      event.target.value = ''; \r\n      \r\n      return;\r\n    }\r\n\r\n    this.formGroup.controls[this.formControlName].setValue(event.target.files[0]);\r\n    this.fileEmit.emit(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  // returnMbSize = computed(() => (bytes: any) => {\r\n  //   if (bytes === null || bytes === undefined) {\r\n  //     return '0 MB';\r\n  //   }\r\n\r\n  //   const mbSize = bytes / (1024 * 1024);\r\n    \r\n  //   return this.formatBytes(mbSize, 2);\r\n  // });\r\n\r\n  progressValue = computed(() => (bytes: any) => {\r\n    if (bytes === null || bytes === undefined) {\r\n      return 0;\r\n    }\r\n\r\n    const mbSize = bytes / (1024 * 1024);\r\n    let progressValue = (Number(mbSize) / this.maxSizeFile()) * 100;\r\n\r\n    // Limita o valor do progresso entre 0 e 100\r\n    return Math.min(Math.max(progressValue, 0), 100);\r\n  });\r\n\r\n  returnProgressLabel = computed(() => (bytes: any) => {\r\n    if (bytes === null || bytes === undefined) {\r\n      return '0 MB';\r\n    }\r\n\r\n    const mbSize = bytes / (1024 * 1024);\r\n    // let progressValue = (Number(mbSize) / this.maxSizeFile()) * 100;\r\n    // this.progressValue.set(progressValue);\r\n    // this.progressValue.set((mbSize / this.maxSizeFile())*100);\r\n    return `${mbSize.toFixed(2)}/${this.maxSizeFile()} MB`;\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    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 =>\r\n      file.type.startsWith(type) ||\r\n      file.type === 'application/xml' ||\r\n      file.type === 'text/xml'\r\n    );\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 if (file.type === 'application/xml' || file.type === 'text/xml') {\r\n      reader.readAsText(file);\r\n    } else {\r\n      reader.readAsArrayBuffer(file);\r\n    }\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      if (type.includes('xml')) types += '.xml, ';\r\n      if (type.includes('plain')) types += '.txt, ';\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]=\"{\r\n    'invalid-border':\r\n      formGroup &&\r\n      formControlName &&\r\n      formGroup.controls[formControlName].invalid &&\r\n      formGroup.controls[formControlName].touched\r\n  }\"\r\n  class=\"border-dashed border-2 border-round-lg border-gray-400 flex justify-content-end relative p-2\"\r\n  (dragover)=\"onDragOver($event)\"\r\n  (dragleave)=\"onDragLeave($event)\"\r\n  (drop)=\"onDrop($event)\"\r\n  [style.minWidth]=\"'20rem'\"\r\n  [style.minHeight]=\"'10rem'\"\r\n  [style.width]=\"widthComponent\"\r\n  [style.height]=\"heightComponent\"\r\n>\r\n  @if(formGroup && formControlName && formGroup.controls[formControlName].value)\r\n  {\r\n  <button\r\n    style=\"background-color: transparent\"\r\n    pButton\r\n    (click)=\"deleteFile()\"\r\n    class=\"absolute transition-colors transition-duration-500 text-red-700 hover:text-red-500 m-1 h-2rem w-2rem\"\r\n    [text]=\"true\"\r\n    [icon]=\"'pi pi-trash'\"\r\n  ></button>\r\n  }\r\n  <div\r\n    class=\"col-12 flex flex-column align-items-center justify-content-center\"\r\n  >\r\n    <div\r\n      class=\"w-full align-items-center justify-content-center col-12\"\r\n      style=\"cursor: pointer\"\r\n      [style.display]=\"formGroup.controls[formControlName].value ? 'none' : 'flex'\"\r\n      (click)=\"fileInput.click()\"\r\n    >\r\n      <input\r\n        type=\"file\"\r\n        (change)=\"onFileSelected($event)\"\r\n        #fileInput\r\n        [accept]=\"setAccept()\"\r\n        hidden\r\n      />\r\n\r\n      @if(formGroup && formControlName &&\r\n      !formGroup.controls[formControlName].value) {\r\n      <div class=\"flex flex-column align-items-center justify-content-center\">\r\n        <!-- @if(tamanhoMaximoPermitido) {\r\n            <p class=\"w-full text-start\">Tamanho maximo permitido ( {{tamanhoMaximoPermitido}} )*</p>\r\n          } -->\r\n        <span\r\n          class=\"material-symbols-outlined mt-2 text-gray-700\"\r\n          style=\"font-size: 2.5rem\"\r\n        >\r\n          cloud_upload\r\n        </span>\r\n\r\n        @if(description) {\r\n        <span class=\"font-medium text-center text-sm text-gray-600\">\r\n          {{ description }}\r\n        </span>\r\n        } @else {\r\n        <span class=\"font-medium text-center text-sm text-gray-600\">\r\n          Arraste e solte o arquivo aqui, ou<br />clique para selecioná-lo\r\n        </span>\r\n        }\r\n      </div>\r\n\r\n      }\r\n    </div>\r\n\r\n    @if(formGroup && formControlName && formGroup.controls[formControlName].value) {\r\n    <div class=\"flex flex-column justify-content-between h-full w-full\">\r\n      <div class=\"col-9 p-0 pt-1\">\r\n        <kv-progress-bar\r\n          [value]=\"\r\n            progressValue()(formGroup.controls[formControlName].value?.size)\r\n          \"\r\n          [showValue]=\"false\"\r\n          [barStyleClass]=\"\r\n            progressValue()(formGroup.controls[formControlName].value?.size) ==\r\n            100\r\n              ? 'bg-red-400'\r\n              : ''\r\n          \"\r\n          [label]=\"\r\n            returnProgressLabel()(\r\n              formGroup.controls[formControlName].value?.size\r\n            )\r\n          \"\r\n        ></kv-progress-bar>\r\n\r\n        @if(progressValue()(formGroup.controls[formControlName].value?.size) ==\r\n        100) {\r\n        <span class=\"text-red-600 text-xs\">Tamanho máximo excedido.</span>\r\n        }\r\n      </div>\r\n\r\n      <div class=\"flex flex-column gap-2\">\r\n        <span class=\"font-medium text-gray-600 text-xs\"\r\n          >Arquivo Selecionado:</span\r\n        >\r\n\r\n        <div class=\"flex flex-row justify-content-between\">\r\n          <span class=\"text-gray-600 text-xs\">{{\r\n            formGroup.controls[formControlName].value?.name\r\n          }}</span>\r\n          <span\r\n            class=\"\r\n          {{\r\n              progressValue()(\r\n                formGroup.controls[formControlName].value?.size\r\n              ) == 100\r\n                ? 'text-red-600'\r\n                : 'text-green-600'\r\n            }} \r\n           text-xs\"\r\n            >{{\r\n              formatBytes(formGroup.controls[formControlName].value?.size)\r\n            }}</span\r\n          >\r\n        </div>\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\r\n&& formGroup.controls[formControlName].touched) {\r\n<p class=\"error-message\">Campo obrigatório</p>\r\n}\r\n"]}
@@ -22,10 +22,10 @@ export class KvIconComponent {
22
22
  this.size = input('medium');
23
23
  }
24
24
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvIconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
25
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvIconComponent, selector: "kv-icon", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: true, transformFunction: null }, shape: { classPropertyName: "shape", publicName: "shape", isSignal: true, isRequired: true, transformFunction: null }, severity: { classPropertyName: "severity", publicName: "severity", isSignal: true, isRequired: true, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"main-container\">\r\n\r\n <div class=\"shape-icon {{ size() }} {{ shape() }} {{ severity() }}\">\r\n\r\n @if(icon()) {\r\n <span class=\"material-symbols-outlined text-white\">\r\n {{ icon() }}\r\n </span>\r\n }\r\n \r\n </div>\r\n \r\n</div>", styles: ["@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-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255;--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165;--kv-danger-color: 220, 53, 69;--kv-success-color: 75, 181, 67;--kv-info-color: 58, 170, 208;--kv-warn-color: 241, 90, 36;--kv-contrast-color: 33, 37, 41}::ng-deep .padrao{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-keevocenter{--kv-color-system: 88,25,153;--kv-color-system-cta: 0, 116, 217;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-holos{--kv-color-system: 241,90,36;--kv-color-system-cta: 224, 168, 35;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 240,240,240;--kv-background-card: 2255,255,255}.system-color{color:rgb(var(--kv-color-system),1)}.bg-system-100{background:rgb(var(--kv-color-system),1)}.bg-system-75{background:rgb(var(--kv-color-system),.75)}.bg-system-50{background:rgb(var(--kv-color-system),.5)}.bg-system-25{background:rgb(var(--kv-color-system),.25)}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter,Inter var,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,Inter var,sans-serif!important}::ng-deep .p-icon,svg{height:.6rem}: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:rgb(var(--kv-color-text))!important;background:linear-gradient(0deg,#00000005 .44%,#0000 49.5%),#fff!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word;border-bottom:1px solid rgb(var(--kv-color-text),.15)}::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-tooltip{font-size:.825rem!important}::ng-deep svg.p-icon{width:.65rem;height:.65rem}::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:#004172;background:#004172}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:hover{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:active{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:disabled{background-color:#002542;opacity:.4;cursor:auto}input{height:1.75rem}::ng-deep .p-checkbox .p-checkbox-box{width:1.125rem;height:1.125rem;border:1.5px solid #d1d5db}::ng-deep p-tablecheckbox p-tableheadercheckbox .p-checkbox{display:flex!important;align-items:center!important;justify-content:right}::ng-deep .p-checkbox{display:flex!important;align-items:center!important;justify-content:center}::ng-deep .p-checkbox-label{font-size:.875rem}:host *{padding:0;margin:0;box-sizing:border-box}.main-container{height:auto}.shape-icon{position:relative;display:flex;justify-content:center;align-items:center;container-type:inline-size;container-name:shape-container}.shape-icon.small{width:1.9rem;height:1.9rem}.shape-icon.medium{width:2.2rem;height:2.2rem}.shape-icon.large{width:2.6rem;height:2.6rem}.shape-icon.system{background-color:rgba(var(--kv-color-system),1)}.shape-icon.success{background-color:rgba(var(--kv-success-color),1)}.shape-icon.info{background-color:rgba(var(--kv-info-color),.4)}.shape-icon.warning{background-color:rgba(var(--kv-warn-color),1)}.shape-icon.danger{background-color:rgba(var(--kv-danger-color),1)}.shape-icon.contrast{background-color:rgba(var(--kv-contrast-color),1)}.shape-icon.circle{border-radius:50%}.shape-icon.square{border-radius:20%}.shape-icon.hexagon{clip-path:polygon(50% 0%,95.5% 27.67%,95.5% 70.1%,50% 100%,4.5% 70.1%,4.5% 27.67%)}.shape-icon .material-symbols-outlined{font-size:70cqi!important}\n"] }); }
25
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvIconComponent, selector: "kv-icon", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: true, transformFunction: null }, shape: { classPropertyName: "shape", publicName: "shape", isSignal: true, isRequired: true, transformFunction: null }, severity: { classPropertyName: "severity", publicName: "severity", isSignal: true, isRequired: true, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"main-container\">\n\n <div class=\"shape-icon {{ size() }} {{ shape() }} {{ severity() }}\">\n\n @if(icon()) {\n <span class=\"material-symbols-outlined text-white\">\n {{ icon() }}\n </span>\n }\n \n </div>\n \n</div>", styles: ["@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-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255;--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165;--kv-danger-color: 220, 53, 69;--kv-success-color: 75, 181, 67;--kv-info-color: 58, 170, 208;--kv-warn-color: 241, 90, 36;--kv-contrast-color: 33, 37, 41}::ng-deep .padrao{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-keevocenter{--kv-color-system: 88,25,153;--kv-color-system-cta: 0, 116, 217;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-holos{--kv-color-system: 241,90,36;--kv-color-system-cta: 224, 168, 35;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 240,240,240;--kv-background-card: 2255,255,255}.system-color{color:rgb(var(--kv-color-system),1)}.bg-system-100{background:rgb(var(--kv-color-system),1)}.bg-system-75{background:rgb(var(--kv-color-system),.75)}.bg-system-50{background:rgb(var(--kv-color-system),.5)}.bg-system-25{background:rgb(var(--kv-color-system),.25)}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter,Inter var,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,Inter var,sans-serif!important}::ng-deep .p-icon,svg{height:.6rem}: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:rgb(var(--kv-color-text))!important;background:linear-gradient(0deg,#00000005 .44%,#0000 49.5%),#fff!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word;border-bottom:1px solid rgb(var(--kv-color-text),.15)}::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-tooltip{font-size:.825rem!important}::ng-deep svg.p-icon{width:.65rem;height:.65rem}::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:#004172;background:#004172}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:hover{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:active{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:disabled{background-color:#002542;opacity:.4;cursor:auto}input{height:1.75rem}::ng-deep .p-checkbox .p-checkbox-box{width:1.125rem;height:1.125rem;border:1.5px solid #d1d5db}::ng-deep p-tablecheckbox p-tableheadercheckbox .p-checkbox{display:flex!important;align-items:center!important;justify-content:right}::ng-deep .p-checkbox{display:flex!important;align-items:center!important;justify-content:center}::ng-deep .p-checkbox-label{font-size:.875rem}:host *{padding:0;margin:0;box-sizing:border-box}.main-container{height:auto}.shape-icon{position:relative;display:flex;justify-content:center;align-items:center;container-type:inline-size;container-name:shape-container}.shape-icon.small{width:1.9rem;height:1.9rem}.shape-icon.medium{width:2.2rem;height:2.2rem}.shape-icon.large{width:2.6rem;height:2.6rem}.shape-icon.system{background-color:rgba(var(--kv-color-system),1)}.shape-icon.success{background-color:rgba(var(--kv-success-color),1)}.shape-icon.info{background-color:rgba(var(--kv-info-color),.4)}.shape-icon.warning{background-color:rgba(var(--kv-warn-color),1)}.shape-icon.danger{background-color:rgba(var(--kv-danger-color),1)}.shape-icon.contrast{background-color:rgba(var(--kv-contrast-color),1)}.shape-icon.circle{border-radius:50%}.shape-icon.square{border-radius:20%}.shape-icon.hexagon{clip-path:polygon(50% 0%,95.5% 27.67%,95.5% 70.1%,50% 100%,4.5% 70.1%,4.5% 27.67%)}.shape-icon .material-symbols-outlined{font-size:70cqi!important}\n"] }); }
26
26
  }
27
27
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvIconComponent, decorators: [{
28
28
  type: Component,
29
- args: [{ selector: 'kv-icon', template: "<div class=\"main-container\">\r\n\r\n <div class=\"shape-icon {{ size() }} {{ shape() }} {{ severity() }}\">\r\n\r\n @if(icon()) {\r\n <span class=\"material-symbols-outlined text-white\">\r\n {{ icon() }}\r\n </span>\r\n }\r\n \r\n </div>\r\n \r\n</div>", styles: ["@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-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255;--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165;--kv-danger-color: 220, 53, 69;--kv-success-color: 75, 181, 67;--kv-info-color: 58, 170, 208;--kv-warn-color: 241, 90, 36;--kv-contrast-color: 33, 37, 41}::ng-deep .padrao{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-keevocenter{--kv-color-system: 88,25,153;--kv-color-system-cta: 0, 116, 217;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-holos{--kv-color-system: 241,90,36;--kv-color-system-cta: 224, 168, 35;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 240,240,240;--kv-background-card: 2255,255,255}.system-color{color:rgb(var(--kv-color-system),1)}.bg-system-100{background:rgb(var(--kv-color-system),1)}.bg-system-75{background:rgb(var(--kv-color-system),.75)}.bg-system-50{background:rgb(var(--kv-color-system),.5)}.bg-system-25{background:rgb(var(--kv-color-system),.25)}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter,Inter var,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,Inter var,sans-serif!important}::ng-deep .p-icon,svg{height:.6rem}: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:rgb(var(--kv-color-text))!important;background:linear-gradient(0deg,#00000005 .44%,#0000 49.5%),#fff!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word;border-bottom:1px solid rgb(var(--kv-color-text),.15)}::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-tooltip{font-size:.825rem!important}::ng-deep svg.p-icon{width:.65rem;height:.65rem}::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:#004172;background:#004172}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:hover{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:active{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:disabled{background-color:#002542;opacity:.4;cursor:auto}input{height:1.75rem}::ng-deep .p-checkbox .p-checkbox-box{width:1.125rem;height:1.125rem;border:1.5px solid #d1d5db}::ng-deep p-tablecheckbox p-tableheadercheckbox .p-checkbox{display:flex!important;align-items:center!important;justify-content:right}::ng-deep .p-checkbox{display:flex!important;align-items:center!important;justify-content:center}::ng-deep .p-checkbox-label{font-size:.875rem}:host *{padding:0;margin:0;box-sizing:border-box}.main-container{height:auto}.shape-icon{position:relative;display:flex;justify-content:center;align-items:center;container-type:inline-size;container-name:shape-container}.shape-icon.small{width:1.9rem;height:1.9rem}.shape-icon.medium{width:2.2rem;height:2.2rem}.shape-icon.large{width:2.6rem;height:2.6rem}.shape-icon.system{background-color:rgba(var(--kv-color-system),1)}.shape-icon.success{background-color:rgba(var(--kv-success-color),1)}.shape-icon.info{background-color:rgba(var(--kv-info-color),.4)}.shape-icon.warning{background-color:rgba(var(--kv-warn-color),1)}.shape-icon.danger{background-color:rgba(var(--kv-danger-color),1)}.shape-icon.contrast{background-color:rgba(var(--kv-contrast-color),1)}.shape-icon.circle{border-radius:50%}.shape-icon.square{border-radius:20%}.shape-icon.hexagon{clip-path:polygon(50% 0%,95.5% 27.67%,95.5% 70.1%,50% 100%,4.5% 70.1%,4.5% 27.67%)}.shape-icon .material-symbols-outlined{font-size:70cqi!important}\n"] }]
29
+ args: [{ selector: 'kv-icon', template: "<div class=\"main-container\">\n\n <div class=\"shape-icon {{ size() }} {{ shape() }} {{ severity() }}\">\n\n @if(icon()) {\n <span class=\"material-symbols-outlined text-white\">\n {{ icon() }}\n </span>\n }\n \n </div>\n \n</div>", styles: ["@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-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255;--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165;--kv-danger-color: 220, 53, 69;--kv-success-color: 75, 181, 67;--kv-info-color: 58, 170, 208;--kv-warn-color: 241, 90, 36;--kv-contrast-color: 33, 37, 41}::ng-deep .padrao{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-keevocenter{--kv-color-system: 88,25,153;--kv-color-system-cta: 0, 116, 217;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-holos{--kv-color-system: 241,90,36;--kv-color-system-cta: 224, 168, 35;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 240,240,240;--kv-background-card: 2255,255,255}.system-color{color:rgb(var(--kv-color-system),1)}.bg-system-100{background:rgb(var(--kv-color-system),1)}.bg-system-75{background:rgb(var(--kv-color-system),.75)}.bg-system-50{background:rgb(var(--kv-color-system),.5)}.bg-system-25{background:rgb(var(--kv-color-system),.25)}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter,Inter var,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,Inter var,sans-serif!important}::ng-deep .p-icon,svg{height:.6rem}: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:rgb(var(--kv-color-text))!important;background:linear-gradient(0deg,#00000005 .44%,#0000 49.5%),#fff!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word;border-bottom:1px solid rgb(var(--kv-color-text),.15)}::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-tooltip{font-size:.825rem!important}::ng-deep svg.p-icon{width:.65rem;height:.65rem}::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:#004172;background:#004172}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:hover{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:active{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:disabled{background-color:#002542;opacity:.4;cursor:auto}input{height:1.75rem}::ng-deep .p-checkbox .p-checkbox-box{width:1.125rem;height:1.125rem;border:1.5px solid #d1d5db}::ng-deep p-tablecheckbox p-tableheadercheckbox .p-checkbox{display:flex!important;align-items:center!important;justify-content:right}::ng-deep .p-checkbox{display:flex!important;align-items:center!important;justify-content:center}::ng-deep .p-checkbox-label{font-size:.875rem}:host *{padding:0;margin:0;box-sizing:border-box}.main-container{height:auto}.shape-icon{position:relative;display:flex;justify-content:center;align-items:center;container-type:inline-size;container-name:shape-container}.shape-icon.small{width:1.9rem;height:1.9rem}.shape-icon.medium{width:2.2rem;height:2.2rem}.shape-icon.large{width:2.6rem;height:2.6rem}.shape-icon.system{background-color:rgba(var(--kv-color-system),1)}.shape-icon.success{background-color:rgba(var(--kv-success-color),1)}.shape-icon.info{background-color:rgba(var(--kv-info-color),.4)}.shape-icon.warning{background-color:rgba(var(--kv-warn-color),1)}.shape-icon.danger{background-color:rgba(var(--kv-danger-color),1)}.shape-icon.contrast{background-color:rgba(var(--kv-contrast-color),1)}.shape-icon.circle{border-radius:50%}.shape-icon.square{border-radius:20%}.shape-icon.hexagon{clip-path:polygon(50% 0%,95.5% 27.67%,95.5% 70.1%,50% 100%,4.5% 70.1%,4.5% 27.67%)}.shape-icon .material-symbols-outlined{font-size:70cqi!important}\n"] }]
30
30
  }] });
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9rdi1pY29uL2t2LWljb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtaWNvbi9rdi1pY29uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDOztBQUl6RDs7Ozs7Ozs7Ozs7OztHQWFHO0FBTUgsTUFBTSxPQUFPLGVBQWU7SUFMNUI7UUFPRSxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBQ2hDLFVBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFtQyxDQUFDO1FBQzFELGFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFxRSxDQUFDO1FBQy9GLFNBQUksR0FBRyxLQUFLLENBQStCLFFBQVEsQ0FBQyxDQUFDO0tBRXREOzhHQVBZLGVBQWU7a0dBQWYsZUFBZSwyaEJDdkI1Qiw0UkFZTTs7MkZEV08sZUFBZTtrQkFMM0IsU0FBUzsrQkFDRSxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IHNldmVyaXR5Q29sb3JBY3RpdmUgfSBmcm9tICcuLi8uLi9hcGkvaGVscGVycy9zZXZlcml0eS1jb2xvcic7XHJcbmltcG9ydCAqIGFzIEljb25Nb2RlbHMgZnJvbSAnLi9rdi1pY29uLm1vZGVsJztcclxuXHJcbi8qKlxyXG4gKiBDb21wb25lbnRlIHBhcmEgZXhpYmnDp8OjbyBkZSDDrWNvbmVzIG5hIGFwbGljYcOnw6NvLlxyXG4gKiBcclxuICogTyBjb21wb25lbnRlIGBrdi1pY29uYCBwZXJtaXRlIHJlbmRlcml6YXIgw61jb25lcyBiYXNlYWRvcyBubyBtb2RlbG8gZm9ybmVjaWRvLlxyXG4gKiBcclxuICogQGV4YW1wbGVcclxuICogYGBgaHRtbFxyXG4gKiA8a3YtaWNvbiBbaWNvbl09XCInaW5mbydcIiBbc2V2ZXJpdHldPVwiJ3N5c3RlbSdcIiBbc2hhcGVdPVwiJ2NpcmNsZSdcIj48L2t2LWljb24+XHJcbiAqIGBgYFxyXG4gKiBcclxuICogQGlucHV0IGljb24gLSBEZWZpbmUgbyDDrWNvbmUgYSBzZXIgZXhpYmlkby5cclxuICogQGlucHV0IHNoYXBlIC0gRGVmaW5lIGEgZm9ybWEgZG8gw61jb25lIChvcMOnw7VlczogJ2NpcmNsZScsICdoZXhhZ29uJywgJ3NxdWFyZScpLlxyXG4gKiBAaW5wdXQgc2V2ZXJpdHkgLSBEZWZpbmUgYSBzZXZlcmlkYWRlIGRvIMOtY29uZSAob3DDp8O1ZXM6ICdzeXN0ZW0nLCAnd2FybmluZycsICdkYW5nZXInLCAnc3VjY2VzcycpLlxyXG4gKi9cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdrdi1pY29uJyxcclxuICB0ZW1wbGF0ZVVybDogJy4va3YtaWNvbi5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4va3YtaWNvbi5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLdkljb25Db21wb25lbnQge1xyXG5cclxuICBpY29uID0gaW5wdXQucmVxdWlyZWQ8c3RyaW5nPigpO1xyXG4gIHNoYXBlID0gaW5wdXQucmVxdWlyZWQ8J2NpcmNsZScgfCAnaGV4YWdvbicgfCAnc3F1YXJlJz4oKTtcclxuICBzZXZlcml0eSA9IGlucHV0LnJlcXVpcmVkPCdzeXN0ZW0nIHwgJ3dhcm5pbmcnIHwgJ2RhbmdlcicgfCAnc3VjY2VzcycgfCAnY29udHJhc3QnIHwgJ2luZm8nPigpO1xyXG4gIHNpemUgPSBpbnB1dDwnc21hbGwnIHwgJ21lZGl1bScgfCAnbGFyZ2UnPignbWVkaXVtJyk7XHJcblxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJtYWluLWNvbnRhaW5lclwiPlxyXG5cclxuICA8ZGl2IGNsYXNzPVwic2hhcGUtaWNvbiB7eyBzaXplKCkgfX0ge3sgc2hhcGUoKSB9fSB7eyBzZXZlcml0eSgpIH19XCI+XHJcblxyXG4gICAgQGlmKGljb24oKSkge1xyXG4gICAgICA8c3BhbiBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWQgdGV4dC13aGl0ZVwiPlxyXG4gICAgICAgIHt7IGljb24oKSB9fVxyXG4gICAgICA8L3NwYW4+XHJcbiAgICB9XHJcbiAgXHJcbiAgPC9kaXY+XHJcbiAgXHJcbjwvZGl2PiJdfQ==
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9rdi1pY29uL2t2LWljb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtaWNvbi9rdi1pY29uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDOztBQUl6RDs7Ozs7Ozs7Ozs7OztHQWFHO0FBTUgsTUFBTSxPQUFPLGVBQWU7SUFMNUI7UUFPRSxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBQ2hDLFVBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFtQyxDQUFDO1FBQzFELGFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFxRSxDQUFDO1FBQy9GLFNBQUksR0FBRyxLQUFLLENBQStCLFFBQVEsQ0FBQyxDQUFDO0tBRXREOzhHQVBZLGVBQWU7a0dBQWYsZUFBZSwyaEJDdkI1QixvUUFZTTs7MkZEV08sZUFBZTtrQkFMM0IsU0FBUzsrQkFDRSxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBzZXZlcml0eUNvbG9yQWN0aXZlIH0gZnJvbSAnLi4vLi4vYXBpL2hlbHBlcnMvc2V2ZXJpdHktY29sb3InO1xuaW1wb3J0ICogYXMgSWNvbk1vZGVscyBmcm9tICcuL2t2LWljb24ubW9kZWwnO1xuXG4vKipcbiAqIENvbXBvbmVudGUgcGFyYSBleGliacOnw6NvIGRlIMOtY29uZXMgbmEgYXBsaWNhw6fDo28uXG4gKiBcbiAqIE8gY29tcG9uZW50ZSBga3YtaWNvbmAgcGVybWl0ZSByZW5kZXJpemFyIMOtY29uZXMgYmFzZWFkb3Mgbm8gbW9kZWxvIGZvcm5lY2lkby5cbiAqIFxuICogQGV4YW1wbGVcbiAqIGBgYGh0bWxcbiAqIDxrdi1pY29uIFtpY29uXT1cIidpbmZvJ1wiIFtzZXZlcml0eV09XCInc3lzdGVtJ1wiIFtzaGFwZV09XCInY2lyY2xlJ1wiPjwva3YtaWNvbj5cbiAqIGBgYFxuICogXG4gKiBAaW5wdXQgaWNvbiAtIERlZmluZSBvIMOtY29uZSBhIHNlciBleGliaWRvLlxuICogQGlucHV0IHNoYXBlIC0gRGVmaW5lIGEgZm9ybWEgZG8gw61jb25lIChvcMOnw7VlczogJ2NpcmNsZScsICdoZXhhZ29uJywgJ3NxdWFyZScpLlxuICogQGlucHV0IHNldmVyaXR5IC0gRGVmaW5lIGEgc2V2ZXJpZGFkZSBkbyDDrWNvbmUgKG9ww6fDtWVzOiAnc3lzdGVtJywgJ3dhcm5pbmcnLCAnZGFuZ2VyJywgJ3N1Y2Nlc3MnKS5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAna3YtaWNvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9rdi1pY29uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4va3YtaWNvbi5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIEt2SWNvbkNvbXBvbmVudCB7XG5cbiAgaWNvbiA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcbiAgc2hhcGUgPSBpbnB1dC5yZXF1aXJlZDwnY2lyY2xlJyB8ICdoZXhhZ29uJyB8ICdzcXVhcmUnPigpO1xuICBzZXZlcml0eSA9IGlucHV0LnJlcXVpcmVkPCdzeXN0ZW0nIHwgJ3dhcm5pbmcnIHwgJ2RhbmdlcicgfCAnc3VjY2VzcycgfCAnY29udHJhc3QnIHwgJ2luZm8nPigpO1xuICBzaXplID0gaW5wdXQ8J3NtYWxsJyB8ICdtZWRpdW0nIHwgJ2xhcmdlJz4oJ21lZGl1bScpO1xuXG59XG4iLCI8ZGl2IGNsYXNzPVwibWFpbi1jb250YWluZXJcIj5cblxuICA8ZGl2IGNsYXNzPVwic2hhcGUtaWNvbiB7eyBzaXplKCkgfX0ge3sgc2hhcGUoKSB9fSB7eyBzZXZlcml0eSgpIH19XCI+XG5cbiAgICBAaWYoaWNvbigpKSB7XG4gICAgICA8c3BhbiBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWQgdGV4dC13aGl0ZVwiPlxuICAgICAgICB7eyBpY29uKCkgfX1cbiAgICAgIDwvc3Bhbj5cbiAgICB9XG4gIFxuICA8L2Rpdj5cbiAgXG48L2Rpdj4iXX0=