keevo-components 2.0.99 → 2.0.100

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.
@@ -1,4 +1,4 @@
1
- import { Component, effect, EventEmitter, input, Input, Output, signal, ViewChild, } from '@angular/core';
1
+ import { Component, effect, EventEmitter, input, Input, Output, signal, untracked, ViewChild, } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "../../api/services/imagens.service";
4
4
  import * as i2 from "../../api/services/notification.service";
@@ -25,8 +25,10 @@ export class KvAvatarComponent {
25
25
  this.imageSource = signal('');
26
26
  this.imageLoaded = signal(false);
27
27
  effect(() => {
28
- if (this.imageUrl())
29
- this.imageSource.set(this.imageUrl());
28
+ untracked(() => {
29
+ if (this.imageUrl())
30
+ this.imageSource.set(this.imageUrl());
31
+ });
30
32
  });
31
33
  }
32
34
  ngOnInit() {
@@ -137,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
137
139
  type: ViewChild,
138
140
  args: ['fileInput']
139
141
  }] } });
140
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-avatar.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-avatar/kv-avatar.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-avatar/kv-avatar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  effect,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  input,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  signal,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { ImagensService } from '../../api/services/imagens.service';\r\nimport { ImageCutterService } from '../../api/services/image.cutter.service';\r\nimport { NotificationService } from '../../api/services/notification.service';\r\n\r\n@Component({\r\n  selector: 'kv-avatar',\r\n  templateUrl: './kv-avatar.component.html',\r\n  styleUrls: ['./kv-avatar.component.scss'],\r\n})\r\n\r\nexport class KvAvatarComponent implements OnInit {\r\n\r\n  constructor(public imageService: ImagensService,\r\n    private notificationService: NotificationService,\r\n    private imageCutterService: ImageCutterService) {\r\n    effect(() => {\r\n      if (this.imageUrl())\r\n        this.imageSource.set(this.imageUrl());\r\n\r\n    })\r\n  }\r\n\r\n\r\n  @Input() borderColor: string = '#002542';\r\n  @Input() btnsColor: string = '#002542';\r\n  @Input() width: number = 135;\r\n  @Input() height: number = 135;\r\n  @Input() btnAlterarFoto: boolean = false;\r\n  @Output() imageUrlChange = new EventEmitter<string>();\r\n  @Output() removerFotoEvent = new EventEmitter<void>();\r\n  @Input() singlaNome: string = '';\r\n\r\n  file: File | null = null;\r\n  existeLogo = false;\r\n  selectedImage: string = '';\r\n\r\n  imageUrl = input<string>('');\r\n  imageSource = signal<string>('');\r\n  imageLoaded = signal<boolean>(false);\r\n\r\n\r\n  @ViewChild('fileInput') fileInput!: ElementRef;\r\n\r\n\r\n\r\n  ngOnInit(): void {\r\n    this.carregaImagemInicial();\r\n  }\r\n\r\n  carregaImagemInicial(): void {\r\n    const imageUrl = this.imageUrl();\r\n\r\n    if (imageUrl && (imageUrl.startsWith('data:image') || imageUrl.startsWith('http') || imageUrl.startsWith('https'))) {\r\n      this.existeLogo = true;\r\n      this.imageSource.set(imageUrl);\r\n    } else if (imageUrl && imageUrl.length > 0) {\r\n      this.existeLogo = true;\r\n      this.imageSource.set('data:image/jpg;base64,' + imageUrl);\r\n    } else {\r\n      this.existeLogo = false;\r\n      // this.imageSource.set(this.imageService.userDefaultImage());\r\n    }\r\n  }\r\n\r\n  onImageLoad() {\r\n    this.imageLoaded.set(true)\r\n  }\r\n\r\n\r\n  openFile() {\r\n    const inputElement: HTMLInputElement | null = document.getElementById('fotoEscolhida') as HTMLInputElement;\r\n    if (inputElement) {\r\n      inputElement.click();\r\n    }\r\n  }\r\n\r\n  changeImage(event: any) {\r\n    const file = event.target.files[0];\r\n    if (file.type.startsWith('image/')) {\r\n\r\n      if (this.btnAlterarFoto == true) {\r\n        this.file = file;\r\n\r\n        const reader = new FileReader();\r\n        reader.onload = async () => {\r\n          try {\r\n            const result = await this.imageCutterService.cut(\r\n              reader.result?.toString() ?? '',\r\n              this.width,\r\n              this.height,\r\n              true,\r\n              true\r\n            );\r\n            this.existeLogo = true;\r\n            this.imageSource.set(result);\r\n            this.selectedImage = result;\r\n            this.imageUrlChange.emit(this.imageSource());\r\n\r\n\r\n          } catch (error) {\r\n            //this.removerFoto();\r\n          }\r\n        };\r\n        reader.readAsDataURL(file);\r\n\r\n      } else {\r\n        // ?! Comportamneto padrão --> Preservar <-- !!!\r\n        this.file = file;\r\n        const reader = new FileReader();\r\n        reader.onload = (e) => {\r\n          this.imageSource.set(reader.result! + '');\r\n        };\r\n        reader.readAsDataURL(file);\r\n        this.imageUrlChange.emit(this.imageSource());\r\n      }\r\n\r\n    } else {\r\n      this.notificationService.toastError('Apenas arquivos de imagem são permitidos.')\r\n    }\r\n\r\n\r\n  }\r\n\r\n  questionRemoverFoto() {\r\n    this.notificationService.question({\r\n      type: 'question',\r\n      message: 'Você tem certeza que deseja retirar a foto desse usuário?',\r\n      accept: () => {\r\n        this.removerFoto()\r\n      },\r\n    });\r\n  }\r\n\r\n  removerFoto() {\r\n    this.imageSource.set('')\r\n    this.removerFotoEvent.emit();\r\n    this.existeLogo = false;\r\n    this.imageUrlChange.emit(this.imageSource());\r\n    this.fileInput.nativeElement.value = '';\r\n  }\r\n\r\n  handleImageError(event: any) {\r\n    this.imageLoaded.set(true)\r\n    // event.target.src = this.imageService.userDefaultImage();\r\n  }\r\n\r\n}\r\n","<div\r\n  class=\"image-container\"\r\n  [style.width.px]=\"width\"\r\n  [style.height.px]=\"height\"\r\n>\r\n  @if(existeLogo) {\r\n  <img\r\n    [src]=\"imageSource()\"\r\n    (load)=\"onImageLoad()\"\r\n    (error)=\"handleImageError($event)\"\r\n    alt=\"Foto\"\r\n    class=\"container-foto\"\r\n    [style.border-color]=\"borderColor\"\r\n    [style.width.px]=\"width\"\r\n    [style.height.px]=\"height\"\r\n  />\r\n  } @else {\r\n  <div\r\n    class=\"container-foto\"\r\n    [style.width.px]=\"width\"\r\n    [style.height.px]=\"height\"\r\n    [style.border-color]=\"borderColor\"\r\n  >\r\n    @if(!singlaNome) {\r\n    <span\r\n      class=\"material-symbols-outlined\"\r\n      [style.fontSize.rem]=\"height * 0.035\"\r\n    >\r\n      person\r\n    </span>\r\n    } @else {\r\n    <span [style.fontSize.rem]=\"height * 0.025\" class=\"text-white\">{{singlaNome}}</span>\r\n    }\r\n  </div>\r\n  }\r\n\r\n  <div class=\"btn\">\r\n    <input\r\n      #fileInput\r\n      *ngIf=\"btnAlterarFoto\"\r\n      id=\"fotoEscolhida\"\r\n      type=\"file\"\r\n      accept=\"image/*\"\r\n      style=\"display: none\"\r\n      (change)=\"changeImage($any($event))\"\r\n    />\r\n\r\n    @if(btnAlterarFoto && !existeLogo) {\r\n    <div\r\n      class=\"btn-avatar\"\r\n      [style.background-color]=\"btnsColor\"\r\n      (click)=\"openFile()\"\r\n    >\r\n      <span class=\"material-symbols-outlined icon-btn-avatar\"\r\n        >photo_camera</span\r\n      >\r\n    </div>\r\n    } @if(btnAlterarFoto && existeLogo) {\r\n    <div\r\n      class=\"btn-avatar\"\r\n      [style.background-color]=\"btnsColor\"\r\n      (click)=\"questionRemoverFoto()\"\r\n    >\r\n      <span class=\"material-symbols-outlined icon-btn-avatar\">delete</span>\r\n    </div>\r\n    }\r\n  </div>\r\n\r\n  <ngx-loading\r\n    [show]=\"!imageLoaded() && existeLogo\"\r\n    full\r\n    class=\"container-foto\"\r\n    [config]=\"{ backdropBorderRadius: '100%', fullScreenBackdrop: false }\"\r\n  ></ngx-loading>\r\n</div>\r\n"]}
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-avatar.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-avatar/kv-avatar.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-avatar/kv-avatar.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,MAAM,EAEN,YAAY,EAEZ,KAAK,EACL,KAAK,EAEL,MAAM,EACN,MAAM,EACN,SAAS,EACT,SAAS,GACV,MAAM,eAAe,CAAC;;;;;;;AAYvB,MAAM,OAAO,iBAAiB;IAE5B,YAAmB,YAA4B,EACrC,mBAAwC,EACxC,kBAAsC;QAF7B,iBAAY,GAAZ,YAAY,CAAgB;QACrC,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,uBAAkB,GAAlB,kBAAkB,CAAoB;QAYvC,gBAAW,GAAW,SAAS,CAAC;QAChC,cAAS,GAAW,SAAS,CAAC;QAC9B,UAAK,GAAW,GAAG,CAAC;QACpB,WAAM,GAAW,GAAG,CAAC;QACrB,mBAAc,GAAY,KAAK,CAAC;QAC/B,mBAAc,GAAG,IAAI,YAAY,EAAU,CAAC;QAC5C,qBAAgB,GAAG,IAAI,YAAY,EAAQ,CAAC;QAC7C,eAAU,GAAW,EAAE,CAAC;QAEjC,SAAI,GAAgB,IAAI,CAAC;QACzB,eAAU,GAAG,KAAK,CAAC;QACnB,kBAAa,GAAW,EAAE,CAAC;QAE3B,aAAQ,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QAC7B,gBAAW,GAAG,MAAM,CAAS,EAAE,CAAC,CAAC;QACjC,gBAAW,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QA1BnC,MAAM,CAAC,GAAG,EAAE;YAEV,SAAS,CAAC,GAAG,EAAE;gBACb,IAAI,IAAI,CAAC,QAAQ,EAAE;oBACjB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;YAC1C,CAAC,CAAC,CAAA;QAEJ,CAAC,CAAC,CAAC;IACL,CAAC;IAyBD,QAAQ;QACN,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,oBAAoB;QAClB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;QAEjC,IAAI,QAAQ,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,QAAQ,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;YACnH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACjC,CAAC;aAAM,IAAI,QAAQ,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC3C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,wBAAwB,GAAG,QAAQ,CAAC,CAAC;QAC5D,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,8DAA8D;QAChE,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;IAC5B,CAAC;IAGD,QAAQ;QACN,MAAM,YAAY,GAA4B,QAAQ,CAAC,cAAc,CAAC,eAAe,CAAqB,CAAC;QAC3G,IAAI,YAAY,EAAE,CAAC;YACjB,YAAY,CAAC,KAAK,EAAE,CAAC;QACvB,CAAC;IACH,CAAC;IAED,WAAW,CAAC,KAAU;QACpB,MAAM,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACnC,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;YAEnC,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,EAAE,CAAC;gBAChC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;gBAEjB,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;gBAChC,MAAM,CAAC,MAAM,GAAG,KAAK,IAAI,EAAE;oBACzB,IAAI,CAAC;wBACH,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAC9C,MAAM,CAAC,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE,EAC/B,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,MAAM,EACX,IAAI,EACJ,IAAI,CACL,CAAC;wBACF,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;wBACvB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;wBAC7B,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC;wBAC5B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;oBAG/C,CAAC;oBAAC,OAAO,KAAK,EAAE,CAAC;wBACf,qBAAqB;oBACvB,CAAC;gBACH,CAAC,CAAC;gBACF,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YAE7B,CAAC;iBAAM,CAAC;gBACN,gDAAgD;gBAChD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;gBACjB,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;gBAChC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,EAAE;oBACpB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,CAAC,MAAO,GAAG,EAAE,CAAC,CAAC;gBAC5C,CAAC,CAAC;gBACF,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;gBAC3B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;YAC/C,CAAC;QAEH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,2CAA2C,CAAC,CAAA;QAClF,CAAC;IAGH,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC;YAChC,IAAI,EAAE,UAAU;YAChB,OAAO,EAAE,2DAA2D;YACpE,MAAM,EAAE,GAAG,EAAE;gBACX,IAAI,CAAC,WAAW,EAAE,CAAA;YACpB,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,WAAW;QACT,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;QACxB,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;QAC7B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QAC7C,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;IAC1C,CAAC;IAED,gBAAgB,CAAC,KAAU;QACzB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;QAC1B,2DAA2D;IAC7D,CAAC;8GAzIU,iBAAiB;kGAAjB,iBAAiB,4pCCzB9B,g+DA2EA;;2FDlDa,iBAAiB;kBAN7B,SAAS;+BACE,WAAW;sJAqBZ,WAAW;sBAAnB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACI,cAAc;sBAAvB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBACE,UAAU;sBAAlB,KAAK;gBAWkB,SAAS;sBAAhC,SAAS;uBAAC,WAAW","sourcesContent":["import {\r\n  Component,\r\n  effect,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  input,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  signal,\r\n  untracked,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { ImagensService } from '../../api/services/imagens.service';\r\nimport { ImageCutterService } from '../../api/services/image.cutter.service';\r\nimport { NotificationService } from '../../api/services/notification.service';\r\n\r\n@Component({\r\n  selector: 'kv-avatar',\r\n  templateUrl: './kv-avatar.component.html',\r\n  styleUrls: ['./kv-avatar.component.scss'],\r\n})\r\n\r\nexport class KvAvatarComponent implements OnInit {\r\n\r\n  constructor(public imageService: ImagensService,\r\n    private notificationService: NotificationService,\r\n    private imageCutterService: ImageCutterService) {\r\n    effect(() => {\r\n\r\n      untracked(() => {\r\n        if (this.imageUrl())\r\n          this.imageSource.set(this.imageUrl());\r\n      })\r\n\r\n    });\r\n  }\r\n\r\n\r\n  @Input() borderColor: string = '#002542';\r\n  @Input() btnsColor: string = '#002542';\r\n  @Input() width: number = 135;\r\n  @Input() height: number = 135;\r\n  @Input() btnAlterarFoto: boolean = false;\r\n  @Output() imageUrlChange = new EventEmitter<string>();\r\n  @Output() removerFotoEvent = new EventEmitter<void>();\r\n  @Input() singlaNome: string = '';\r\n\r\n  file: File | null = null;\r\n  existeLogo = false;\r\n  selectedImage: string = '';\r\n\r\n  imageUrl = input<string>('');\r\n  imageSource = signal<string>('');\r\n  imageLoaded = signal<boolean>(false);\r\n\r\n\r\n  @ViewChild('fileInput') fileInput!: ElementRef;\r\n\r\n\r\n\r\n  ngOnInit(): void {\r\n    this.carregaImagemInicial();\r\n  }\r\n\r\n  carregaImagemInicial(): void {\r\n    const imageUrl = this.imageUrl();\r\n\r\n    if (imageUrl && (imageUrl.startsWith('data:image') || imageUrl.startsWith('http') || imageUrl.startsWith('https'))) {\r\n      this.existeLogo = true;\r\n      this.imageSource.set(imageUrl);\r\n    } else if (imageUrl && imageUrl.length > 0) {\r\n      this.existeLogo = true;\r\n      this.imageSource.set('data:image/jpg;base64,' + imageUrl);\r\n    } else {\r\n      this.existeLogo = false;\r\n      // this.imageSource.set(this.imageService.userDefaultImage());\r\n    }\r\n  }\r\n\r\n  onImageLoad() {\r\n    this.imageLoaded.set(true)\r\n  }\r\n\r\n\r\n  openFile() {\r\n    const inputElement: HTMLInputElement | null = document.getElementById('fotoEscolhida') as HTMLInputElement;\r\n    if (inputElement) {\r\n      inputElement.click();\r\n    }\r\n  }\r\n\r\n  changeImage(event: any) {\r\n    const file = event.target.files[0];\r\n    if (file.type.startsWith('image/')) {\r\n\r\n      if (this.btnAlterarFoto == true) {\r\n        this.file = file;\r\n\r\n        const reader = new FileReader();\r\n        reader.onload = async () => {\r\n          try {\r\n            const result = await this.imageCutterService.cut(\r\n              reader.result?.toString() ?? '',\r\n              this.width,\r\n              this.height,\r\n              true,\r\n              true\r\n            );\r\n            this.existeLogo = true;\r\n            this.imageSource.set(result);\r\n            this.selectedImage = result;\r\n            this.imageUrlChange.emit(this.imageSource());\r\n\r\n\r\n          } catch (error) {\r\n            //this.removerFoto();\r\n          }\r\n        };\r\n        reader.readAsDataURL(file);\r\n\r\n      } else {\r\n        // ?! Comportamneto padrão --> Preservar <-- !!!\r\n        this.file = file;\r\n        const reader = new FileReader();\r\n        reader.onload = (e) => {\r\n          this.imageSource.set(reader.result! + '');\r\n        };\r\n        reader.readAsDataURL(file);\r\n        this.imageUrlChange.emit(this.imageSource());\r\n      }\r\n\r\n    } else {\r\n      this.notificationService.toastError('Apenas arquivos de imagem são permitidos.')\r\n    }\r\n\r\n\r\n  }\r\n\r\n  questionRemoverFoto() {\r\n    this.notificationService.question({\r\n      type: 'question',\r\n      message: 'Você tem certeza que deseja retirar a foto desse usuário?',\r\n      accept: () => {\r\n        this.removerFoto()\r\n      },\r\n    });\r\n  }\r\n\r\n  removerFoto() {\r\n    this.imageSource.set('')\r\n    this.removerFotoEvent.emit();\r\n    this.existeLogo = false;\r\n    this.imageUrlChange.emit(this.imageSource());\r\n    this.fileInput.nativeElement.value = '';\r\n  }\r\n\r\n  handleImageError(event: any) {\r\n    this.imageLoaded.set(true)\r\n    // event.target.src = this.imageService.userDefaultImage();\r\n  }\r\n\r\n}\r\n","<div\r\n  class=\"image-container\"\r\n  [style.width.px]=\"width\"\r\n  [style.height.px]=\"height\"\r\n>\r\n  @if(existeLogo) {\r\n  <img\r\n    [src]=\"imageSource()\"\r\n    (load)=\"onImageLoad()\"\r\n    (error)=\"handleImageError($event)\"\r\n    alt=\"Foto\"\r\n    class=\"container-foto\"\r\n    [style.border-color]=\"borderColor\"\r\n    [style.width.px]=\"width\"\r\n    [style.height.px]=\"height\"\r\n  />\r\n  } @else {\r\n  <div\r\n    class=\"container-foto\"\r\n    [style.width.px]=\"width\"\r\n    [style.height.px]=\"height\"\r\n    [style.border-color]=\"borderColor\"\r\n  >\r\n    @if(!singlaNome) {\r\n    <span\r\n      class=\"material-symbols-outlined\"\r\n      [style.fontSize.rem]=\"height * 0.035\"\r\n    >\r\n      person\r\n    </span>\r\n    } @else {\r\n    <span [style.fontSize.rem]=\"height * 0.025\" class=\"text-white\">{{singlaNome}}</span>\r\n    }\r\n  </div>\r\n  }\r\n\r\n  <div class=\"btn\">\r\n    <input\r\n      #fileInput\r\n      *ngIf=\"btnAlterarFoto\"\r\n      id=\"fotoEscolhida\"\r\n      type=\"file\"\r\n      accept=\"image/*\"\r\n      style=\"display: none\"\r\n      (change)=\"changeImage($any($event))\"\r\n    />\r\n\r\n    @if(btnAlterarFoto && !existeLogo) {\r\n    <div\r\n      class=\"btn-avatar\"\r\n      [style.background-color]=\"btnsColor\"\r\n      (click)=\"openFile()\"\r\n    >\r\n      <span class=\"material-symbols-outlined icon-btn-avatar\"\r\n        >photo_camera</span\r\n      >\r\n    </div>\r\n    } @if(btnAlterarFoto && existeLogo) {\r\n    <div\r\n      class=\"btn-avatar\"\r\n      [style.background-color]=\"btnsColor\"\r\n      (click)=\"questionRemoverFoto()\"\r\n    >\r\n      <span class=\"material-symbols-outlined icon-btn-avatar\">delete</span>\r\n    </div>\r\n    }\r\n  </div>\r\n\r\n  <ngx-loading\r\n    [show]=\"!imageLoaded() && existeLogo\"\r\n    full\r\n    class=\"container-foto\"\r\n    [config]=\"{ backdropBorderRadius: '100%', fullScreenBackdrop: false }\"\r\n  ></ngx-loading>\r\n</div>\r\n"]}