keevo-components 1.8.486 → 1.8.488

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.
@@ -15,9 +15,9 @@ export class ImageCutterService {
15
15
  constructor(dialogservice) {
16
16
  this.dialogservice = dialogservice;
17
17
  }
18
- cut(imageBase64, width, height, indCircle = false) {
18
+ cut(imageBase64, width, height, indCircle = false, avatar) {
19
19
  const cutConfig = { imageBase64, width, height, indCircle };
20
- this.abrirModal(cutConfig);
20
+ this.abrirModal(cutConfig, avatar);
21
21
  return new Promise((resolve, reject) => {
22
22
  window.addEventListener('cropImage', (event) => {
23
23
  if (event.detail.status == true) {
@@ -29,15 +29,19 @@ export class ImageCutterService {
29
29
  });
30
30
  });
31
31
  }
32
- abrirModal(cutConfig) {
32
+ abrirModal(cutConfig, avatar) {
33
+ let quality = 100;
34
+ if (avatar) {
35
+ quality = 80;
36
+ }
33
37
  const params = {
34
38
  closable: true,
35
39
  maximizable: false,
36
40
  popup: true,
37
41
  width: '75vw',
38
42
  header: `Cortar`,
39
- id: { imagem: cutConfig.imageBase64, width: cutConfig.width, height: cutConfig.height, indCircle: cutConfig.indCircle },
40
- styleClass: 'modal'
43
+ id: { imagem: cutConfig.imageBase64, width: cutConfig.width, height: cutConfig.height, indCircle: cutConfig.indCircle, quality: quality },
44
+ styleClass: 'modal',
41
45
  };
42
46
  const dialogRef = FormService.openDialog(this.dialogservice, SimpleComponent, () => { }, params);
43
47
  }
@@ -49,11 +53,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
49
53
  args: [{ providedIn: 'root' }]
50
54
  }], ctorParameters: () => [{ type: i1.DialogService }] });
51
55
  class SimpleComponent {
52
- constructor(dynamicDialogRef, dialogService) {
56
+ constructor(dynamicDialogRef, dialogService, dynamicDialogConfig) {
53
57
  this.dynamicDialogRef = dynamicDialogRef;
54
58
  this.dialogService = dialogService;
59
+ this.dynamicDialogConfig = dynamicDialogConfig;
55
60
  this.imageChangedEvent = null;
56
61
  this.croppedImage = '';
62
+ this.quality = this.dynamicDialogConfig.data.id.quality;
57
63
  //#region Variáveis de controle
58
64
  this._variaviesDialog = signal(null);
59
65
  this.aspectRatio = signal(1 / 1);
@@ -112,7 +118,7 @@ class SimpleComponent {
112
118
  } }));
113
119
  this.closeCropModal();
114
120
  }
115
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: SimpleComponent, deps: [{ token: i1.DynamicDialogRef }, { token: i1.DialogService }], target: i0.ɵɵFactoryTarget.Component }); }
121
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: SimpleComponent, deps: [{ token: i1.DynamicDialogRef }, { token: i1.DialogService }, { token: i1.DynamicDialogConfig }], target: i0.ɵɵFactoryTarget.Component }); }
116
122
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: SimpleComponent, isStandalone: true, selector: "app-simple-component", ngImport: i0, template: `
117
123
  <div class="modal-content">
118
124
 
@@ -125,7 +131,7 @@ class SimpleComponent {
125
131
  (loadImageFailed)="loadImageFailed()"
126
132
  [roundCropper]="this._variaviesDialog()?.indCircle"
127
133
  [maintainAspectRatio]="true"
128
- [imageQuality]="100"
134
+ [imageQuality]="quality"
129
135
  format="jpeg"
130
136
  output='base64'
131
137
  alignImage="center"
@@ -156,7 +162,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
156
162
  (loadImageFailed)="loadImageFailed()"
157
163
  [roundCropper]="this._variaviesDialog()?.indCircle"
158
164
  [maintainAspectRatio]="true"
159
- [imageQuality]="100"
165
+ [imageQuality]="quality"
160
166
  format="jpeg"
161
167
  output='base64'
162
168
  alignImage="center"
@@ -181,5 +187,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
181
187
  KvLabelModule,
182
188
  ImageCropperComponent
183
189
  ], styles: ["img{border-style:solid;border-width:2px;border-radius:50%;object-fit:cover}i{font-size:22px}.botao-alterar-foto{border-style:none;width:max-content;background-color:#002542;color:#000;font-weight:700;cursor:pointer;padding:7px 9px}.botao-alterar-foto i{color:#fff}.botao-excluir-foto{border-style:none;width:max-content;background-color:#002542;color:#000;font-weight:700;cursor:pointer;padding:7px 9px}.botao-excluir-foto i{color:#fff}.btn{position:absolute;top:87%;left:87%;transform:translate(-50%,-50%)}.image-container{display:inline-block;position:relative}.modal-content{height:60vh;position:relative;background-color:#fefefe;margin:1% auto;padding:20px;width:80%;max-width:fit-content;text-align:center;border-radius:12px;display:flex;align-items:center;justify-content:center}.crop-container{display:flex;justify-content:center;align-items:center}.crop-canvas{border:1px solid #d1d5db;border-radius:12px;width:100%;height:auto}.crop-border{position:absolute;border:2px dashed #9ca3af;pointer-events:none}.zoom-container{padding-top:20px;padding-bottom:20px}.button-container{display:flex;align-items:center;justify-content:flex-end;flex-direction:row;margin-top:24px;position:fixed;bottom:0;background:#fff;width:90%;padding:15px}\n"] }]
184
- }], ctorParameters: () => [{ type: i1.DynamicDialogRef }, { type: i1.DialogService }] });
185
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.cutter.service.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/api/services/image.cutter.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentRef, Injectable, signal } from '@angular/core';\r\nimport { DialogService, DynamicDialogComponent, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { DialogModule } from 'primeng/dialog';\r\nimport { ImageCroppedEvent, ImageCropperComponent, LoadedImage } from 'ngx-image-cropper';\r\n\r\n@Injectable({providedIn: 'root'})\r\nexport class ImageCutterService {\r\n\r\n  constructor(private readonly dialogservice: DialogService) {}\r\n\r\n  cut(imageBase64: string, width: number, height: number, indCircle: boolean = false): Promise<string> {\r\n    const cutConfig = { imageBase64, width, height, indCircle };\r\n    this.abrirModal(cutConfig);\r\n\r\n    return new Promise<string>((resolve, reject) => {\r\n      window.addEventListener('cropImage', (event: any) => {\r\n        if(event.detail.status == true ) {\r\n          resolve(event.detail.result);\r\n        }else{\r\n          reject('Operacao cancelada.');\r\n        }\r\n      });\r\n    });\r\n  }\r\n\r\n  abrirModal(cutConfig: { imageBase64: string, width: number, height: number, indCircle: boolean }) {\r\n    const params =       {\r\n      closable: true,\r\n      maximizable: false,\r\n      popup: true,\r\n      width: '75vw',\r\n      header: `Cortar` ,\r\n      id: { imagem: cutConfig.imageBase64, width: cutConfig.width, height: cutConfig.height, indCircle: cutConfig.indCircle },\r\n      styleClass: 'modal'\r\n    }\r\n    const dialogRef: DynamicDialogRef = FormService.openDialog(this.dialogservice, SimpleComponent, ()=>{}, params);\r\n  }\r\n\r\n}\r\n\r\n\r\n// ? Componente de modal usado no cutter\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { KvLabelModule } from '../../components/kv-label/kv-label.module';\r\nimport { FormService } from './form.service';\r\nimport { KvModalModule } from '../../components/kv-modal/kv-modal.module';\r\nimport { KvButtonModule } from '../../components/kv-button/kv-button.module';\r\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\r\n\r\n@Component({\r\n  selector: 'app-simple-component',\r\n  template: `\r\n      <div class=\"modal-content\">\r\n\r\n          <image-cropper\r\n            [imageBase64]=\"_variaviesDialog()?.imagem\"\r\n            (imageCropped)=\"imageCropped($event)\"\r\n            [aspectRatio]=\"aspectRatio()\"\r\n            (imageLoaded)=\"imageLoaded($event)\"\r\n            (cropperReady)=\"cropperReady()\"\r\n            (loadImageFailed)=\"loadImageFailed()\"\r\n            [roundCropper]=\"this._variaviesDialog()?.indCircle\"\r\n            [maintainAspectRatio]=\"true\"\r\n            [imageQuality]=\"100\"\r\n            format=\"jpeg\"\r\n            output='base64'\r\n            alignImage=\"center\"\r\n          />\r\n\r\n          \r\n        </div>\r\n        <div class=\"button-container\">\r\n          <kv-button label=\"Cancelar\" severity=\"tertiary\" icon=\"close\" (click)=\"cancel()\"></kv-button>\r\n          <kv-button label=\"Recortar\" severity=\"primary\" icon=\"crop\" (click)=\"cropImage()\" class=\"ml-2\"></kv-button>\r\n        </div>\r\n\r\n\r\n\r\n  `,\r\n  styles: [`\r\n\r\n    img {\r\n      border-style: solid;\r\n      border-width: 2px;\r\n      border-radius: 50%;\r\n      object-fit: cover;\r\n    }\r\n    \r\n    i {\r\n      font-size: 22px;\r\n    }\r\n    \r\n    .botao-alterar-foto {\r\n      border-style: none;\r\n      width: max-content;\r\n      background-color: #002542;\r\n      color: black;\r\n      font-weight: bold;\r\n      cursor: pointer;\r\n      padding: 7px 9px;\r\n    }\r\n    \r\n    .botao-alterar-foto i {\r\n      color: #fff;\r\n    }\r\n    \r\n    .botao-excluir-foto {\r\n      border-style: none;\r\n      width: max-content;\r\n      background-color: #002542;\r\n      color: black;\r\n      font-weight: bold;\r\n      cursor: pointer;\r\n      padding: 7px 9px;\r\n    }\r\n    \r\n    .botao-excluir-foto i {\r\n      color: #fff;\r\n    }\r\n    \r\n    .btn {\r\n      position: absolute;\r\n      top: 87%;\r\n      left: 87%;\r\n      transform: translate(-50%, -50%);\r\n    }\r\n    \r\n    .image-container {\r\n      display: inline-block;\r\n      position: relative;\r\n    }\r\n    \r\n    .modal-content {\r\n      height: 60vh;\r\n      position: relative;\r\n      background-color: #fefefe;\r\n      margin: 1% auto;\r\n      padding: 20px;\r\n      width: 80%;\r\n      max-width: fit-content;\r\n      text-align: center;\r\n      border-radius: 12px;\r\n      display: flex;\r\n      align-items: center;\r\n      justify-content: center;\r\n    }\r\n    \r\n    .crop-container {\r\n      display: flex;\r\n      justify-content: center;\r\n      align-items: center;\r\n    }\r\n    \r\n    .crop-canvas {\r\n      border: 1px solid #d1d5db;\r\n      border-radius: 12px;\r\n      width: 100%;\r\n      height: auto;\r\n    }\r\n    \r\n    .crop-border {\r\n      position: absolute;\r\n      border: 2px dashed #9ca3af;\r\n      pointer-events: none;\r\n    }\r\n    \r\n    .zoom-container {\r\n      padding-top: 20px;\r\n      padding-bottom: 20px;\r\n    }\r\n    \r\n    .button-container {\r\n      display: flex;\r\n      align-items: center;\r\n      justify-content: flex-end;\r\n      flex-direction: row;\r\n      margin-top: 24px;\r\n      position: fixed;\r\n      bottom: 0px;\r\n      background: #fff;\r\n      width: 90%;\r\n      padding: 15px;\r\n    }\r\n    \r\n    \r\n    \r\n      `],\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    DialogModule,\r\n    KvModalModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    KvButtonModule,\r\n    KvLabelModule,\r\n    ImageCropperComponent\r\n  ]\r\n})\r\n\r\nclass SimpleComponent {\r\n\r\n  constructor(private dynamicDialogRef: DynamicDialogRef, private readonly dialogService: DialogService) {}\r\n  imageChangedEvent: Event | null = null;\r\n  croppedImage: SafeUrl  = '';\r\n  \r\n    \r\n    fileChangeEvent(event: Event): void {\r\n      this.imageChangedEvent = event;\r\n    }\r\n    imageCropped(event: ImageCroppedEvent) {\r\n      this.croppedImage = event.base64!;\r\n    }\r\n    imageLoaded(image: LoadedImage) {}\r\n    cropperReady() {}\r\n    loadImageFailed() {}\r\n\r\n\r\n\r\n  //#region Variáveis de controle\r\n    _variaviesDialog = signal<{ imagem: string, width: number, height: number, indCircle: boolean }|null>(null)\r\n    private dialogInstance!:DynamicDialogComponent;\r\n    aspectRatio = signal<any>(1/1)\r\n  //#endregion\r\n\r\n\r\n  ngAfterContentInit(): void {\r\n    this.recuperarVariaviesDialog()\r\n    this.recuperaInstanciaDialog()\r\n    this.setAspectRatio()\r\n  }\r\n\r\n\r\n\r\n  setAspectRatio(width: number = this._variaviesDialog()?.width!, height: number = this._variaviesDialog()?.height!) {\r\n    const gcd = (a: number, b: number): number => (b === 0 ? a : gcd(b, a % b));\r\n    const divisor = gcd(width, height);\r\n    const aspectWidth = width / divisor;\r\n    const aspectHeight = height / divisor;\r\n    this.aspectRatio.set(aspectWidth/aspectHeight)\r\n\r\n  }\r\n\r\n  //#region Métodos de recuperação de dados\r\n  recuperaInstanciaDialog(): DynamicDialogComponent {\r\n    const arr: Map<DynamicDialogRef<any>, ComponentRef<any>> = this.dialogService.dialogComponentRefMap\r\n    const entries = arr.entries();\r\n    const firstEntry = entries.next().value;\r\n    const [firstKey, firstValue] = firstEntry!;\r\n    const instance = this.dialogService.getInstance(firstKey)\r\n    this.dialogInstance = instance\r\n    return instance\r\n  }\r\n\r\n  recuperarVariaviesDialog(): void{\r\n    this._variaviesDialog.set(this.recuperaInstanciaDialog().data.id)\r\n  }\r\n  //#endregion\r\n\r\n\r\n  //#region Métodos de corte e fechamento do modal\r\n  cropImage() {\r\n          window.dispatchEvent(new CustomEvent('cropImage', { detail: {\r\n            result: this.croppedImage,\r\n            status: true\r\n          } }));\r\n          this.closeCropModal();\r\n  }\r\n\r\n  closeCropModal() {\r\n    this.dialogInstance.close();\r\n  }\r\n\r\n  cancel(){\r\n    window.dispatchEvent(new CustomEvent('cropImage', { detail:{\r\n      result: Promise.resolve('cancel'),\r\n      status: false\r\n    } }));\r\n\r\n    this.closeCropModal()\r\n  }\r\n  //#endregion\r\n\r\n}\r\n"]}
190
+ }], ctorParameters: () => [{ type: i1.DynamicDialogRef }, { type: i1.DialogService }, { type: i1.DynamicDialogConfig }] });
191
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.cutter.service.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/api/services/image.cutter.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentRef, Injectable, signal } from '@angular/core';\r\nimport { DialogService, DynamicDialogComponent, DynamicDialogConfig, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { DialogModule } from 'primeng/dialog';\r\nimport { ImageCroppedEvent, ImageCropperComponent, LoadedImage } from 'ngx-image-cropper';\r\n\r\n@Injectable({providedIn: 'root'})\r\nexport class ImageCutterService {\r\n\r\n  constructor(private readonly dialogservice: DialogService) {}\r\n\r\n  cut(imageBase64: string, width: number, height: number, indCircle: boolean = false, avatar?: boolean): Promise<string> {\r\n    const cutConfig = { imageBase64, width, height, indCircle };\r\n    this.abrirModal(cutConfig, avatar);\r\n\r\n    return new Promise<string>((resolve, reject) => {\r\n      window.addEventListener('cropImage', (event: any) => {\r\n        if(event.detail.status == true ) {\r\n          resolve(event.detail.result);\r\n        }else{\r\n          reject('Operacao cancelada.');\r\n        }\r\n      });\r\n    });\r\n  }\r\n\r\n  abrirModal(cutConfig: { imageBase64: string, width: number, height: number, indCircle: boolean }, avatar?: boolean) {\r\n    let quality = 100\r\n    if(avatar) {\r\n      quality = 80\r\n    }\r\n    const params =       {\r\n      closable: true,\r\n      maximizable: false,\r\n      popup: true,\r\n      width: '75vw',\r\n      header: `Cortar` ,\r\n      id: { imagem: cutConfig.imageBase64, width: cutConfig.width, height: cutConfig.height, indCircle: cutConfig.indCircle, quality: quality },\r\n      styleClass: 'modal',\r\n    }\r\n    const dialogRef: DynamicDialogRef = FormService.openDialog(this.dialogservice, SimpleComponent, ()=>{}, params);\r\n  }\r\n\r\n}\r\n\r\n\r\n// ? Componente de modal usado no cutter\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { KvLabelModule } from '../../components/kv-label/kv-label.module';\r\nimport { FormService } from './form.service';\r\nimport { KvModalModule } from '../../components/kv-modal/kv-modal.module';\r\nimport { KvButtonModule } from '../../components/kv-button/kv-button.module';\r\nimport { DomSanitizer, SafeUrl } from '@angular/platform-browser';\r\n\r\n@Component({\r\n  selector: 'app-simple-component',\r\n  template: `\r\n      <div class=\"modal-content\">\r\n\r\n          <image-cropper\r\n            [imageBase64]=\"_variaviesDialog()?.imagem\"\r\n            (imageCropped)=\"imageCropped($event)\"\r\n            [aspectRatio]=\"aspectRatio()\"\r\n            (imageLoaded)=\"imageLoaded($event)\"\r\n            (cropperReady)=\"cropperReady()\"\r\n            (loadImageFailed)=\"loadImageFailed()\"\r\n            [roundCropper]=\"this._variaviesDialog()?.indCircle\"\r\n            [maintainAspectRatio]=\"true\"\r\n            [imageQuality]=\"quality\"\r\n            format=\"jpeg\"\r\n            output='base64'\r\n            alignImage=\"center\"\r\n          />\r\n\r\n          \r\n        </div>\r\n        <div class=\"button-container\">\r\n          <kv-button label=\"Cancelar\" severity=\"tertiary\" icon=\"close\" (click)=\"cancel()\"></kv-button>\r\n          <kv-button label=\"Recortar\" severity=\"primary\" icon=\"crop\" (click)=\"cropImage()\" class=\"ml-2\"></kv-button>\r\n        </div>\r\n\r\n\r\n\r\n  `,\r\n  styles: [`\r\n\r\n    img {\r\n      border-style: solid;\r\n      border-width: 2px;\r\n      border-radius: 50%;\r\n      object-fit: cover;\r\n    }\r\n    \r\n    i {\r\n      font-size: 22px;\r\n    }\r\n    \r\n    .botao-alterar-foto {\r\n      border-style: none;\r\n      width: max-content;\r\n      background-color: #002542;\r\n      color: black;\r\n      font-weight: bold;\r\n      cursor: pointer;\r\n      padding: 7px 9px;\r\n    }\r\n    \r\n    .botao-alterar-foto i {\r\n      color: #fff;\r\n    }\r\n    \r\n    .botao-excluir-foto {\r\n      border-style: none;\r\n      width: max-content;\r\n      background-color: #002542;\r\n      color: black;\r\n      font-weight: bold;\r\n      cursor: pointer;\r\n      padding: 7px 9px;\r\n    }\r\n    \r\n    .botao-excluir-foto i {\r\n      color: #fff;\r\n    }\r\n    \r\n    .btn {\r\n      position: absolute;\r\n      top: 87%;\r\n      left: 87%;\r\n      transform: translate(-50%, -50%);\r\n    }\r\n    \r\n    .image-container {\r\n      display: inline-block;\r\n      position: relative;\r\n    }\r\n    \r\n    .modal-content {\r\n      height: 60vh;\r\n      position: relative;\r\n      background-color: #fefefe;\r\n      margin: 1% auto;\r\n      padding: 20px;\r\n      width: 80%;\r\n      max-width: fit-content;\r\n      text-align: center;\r\n      border-radius: 12px;\r\n      display: flex;\r\n      align-items: center;\r\n      justify-content: center;\r\n    }\r\n    \r\n    .crop-container {\r\n      display: flex;\r\n      justify-content: center;\r\n      align-items: center;\r\n    }\r\n    \r\n    .crop-canvas {\r\n      border: 1px solid #d1d5db;\r\n      border-radius: 12px;\r\n      width: 100%;\r\n      height: auto;\r\n    }\r\n    \r\n    .crop-border {\r\n      position: absolute;\r\n      border: 2px dashed #9ca3af;\r\n      pointer-events: none;\r\n    }\r\n    \r\n    .zoom-container {\r\n      padding-top: 20px;\r\n      padding-bottom: 20px;\r\n    }\r\n    \r\n    .button-container {\r\n      display: flex;\r\n      align-items: center;\r\n      justify-content: flex-end;\r\n      flex-direction: row;\r\n      margin-top: 24px;\r\n      position: fixed;\r\n      bottom: 0px;\r\n      background: #fff;\r\n      width: 90%;\r\n      padding: 15px;\r\n    }\r\n    \r\n    \r\n    \r\n      `],\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    DialogModule,\r\n    KvModalModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    KvButtonModule,\r\n    KvLabelModule,\r\n    ImageCropperComponent\r\n  ]\r\n})\r\n\r\nclass SimpleComponent {\r\n\r\n  constructor(private dynamicDialogRef: DynamicDialogRef, private readonly dialogService: DialogService, private dynamicDialogConfig: DynamicDialogConfig) {}\r\n  imageChangedEvent: Event | null = null;\r\n  croppedImage: SafeUrl  = '';\r\n  \r\n  quality: number = this.dynamicDialogConfig.data.id.quality;\r\n    \r\n    fileChangeEvent(event: Event): void {\r\n      this.imageChangedEvent = event;\r\n    }\r\n    imageCropped(event: ImageCroppedEvent) {\r\n      this.croppedImage = event.base64!;\r\n    }\r\n    imageLoaded(image: LoadedImage) {}\r\n    cropperReady() {}\r\n    loadImageFailed() {}\r\n\r\n\r\n\r\n  //#region Variáveis de controle\r\n    _variaviesDialog = signal<{ imagem: string, width: number, height: number, indCircle: boolean }|null>(null)\r\n    private dialogInstance!:DynamicDialogComponent;\r\n    aspectRatio = signal<any>(1/1)\r\n  //#endregion\r\n\r\n\r\n  ngAfterContentInit(): void {\r\n    this.recuperarVariaviesDialog()\r\n    this.recuperaInstanciaDialog()\r\n    this.setAspectRatio()\r\n  }\r\n\r\n\r\n\r\n  setAspectRatio(width: number = this._variaviesDialog()?.width!, height: number = this._variaviesDialog()?.height!) {\r\n    const gcd = (a: number, b: number): number => (b === 0 ? a : gcd(b, a % b));\r\n    const divisor = gcd(width, height);\r\n    const aspectWidth = width / divisor;\r\n    const aspectHeight = height / divisor;\r\n    this.aspectRatio.set(aspectWidth/aspectHeight)\r\n\r\n  }\r\n\r\n  //#region Métodos de recuperação de dados\r\n  recuperaInstanciaDialog(): DynamicDialogComponent {\r\n    const arr: Map<DynamicDialogRef<any>, ComponentRef<any>> = this.dialogService.dialogComponentRefMap\r\n    const entries = arr.entries();\r\n    const firstEntry = entries.next().value;\r\n    const [firstKey, firstValue] = firstEntry!;\r\n    const instance = this.dialogService.getInstance(firstKey)\r\n    this.dialogInstance = instance\r\n    return instance\r\n  }\r\n\r\n  recuperarVariaviesDialog(): void{\r\n    this._variaviesDialog.set(this.recuperaInstanciaDialog().data.id)\r\n  }\r\n  //#endregion\r\n\r\n\r\n  //#region Métodos de corte e fechamento do modal\r\n  cropImage() {\r\n          window.dispatchEvent(new CustomEvent('cropImage', { detail: {\r\n            result: this.croppedImage,\r\n            status: true\r\n          } }));\r\n          this.closeCropModal();\r\n  }\r\n\r\n  closeCropModal() {\r\n    this.dialogInstance.close();\r\n  }\r\n\r\n  cancel(){\r\n    window.dispatchEvent(new CustomEvent('cropImage', { detail:{\r\n      result: Promise.resolve('cancel'),\r\n      status: false\r\n    } }));\r\n\r\n    this.closeCropModal()\r\n  }\r\n  //#endregion\r\n\r\n}\r\n"]}
@@ -59,7 +59,7 @@ export class KvAvatarComponent {
59
59
  const reader = new FileReader();
60
60
  reader.onload = async () => {
61
61
  try {
62
- const result = await this.imageCutterService.cut(reader.result?.toString() ?? '', this.width, this.height, true);
62
+ const result = await this.imageCutterService.cut(reader.result?.toString() ?? '', this.width, this.height, true, true);
63
63
  this.existeLogo = true;
64
64
  this.imageSource.set(result);
65
65
  this.selectedImage = result;
@@ -87,16 +87,7 @@ export class KvAvatarComponent {
87
87
  }
88
88
  }
89
89
  questionRemoverFoto() {
90
- const msg = '<p>Você tem certeza que deseja retirar a foto desse usuário?</p>';
91
- this.notificationService.question({
92
- type: 'question',
93
- message: msg,
94
- accept: (data) => {
95
- this.removerFoto();
96
- },
97
- reject: (data) => {
98
- }
99
- });
90
+ this.removerFoto();
100
91
  }
101
92
  removerFoto() {
102
93
  this.imageSource.set('');
@@ -133,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
133
124
  type: ViewChild,
134
125
  args: ['fileInput']
135
126
  }] } });
136
- //# 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  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 { NotificationService } from '../../api/services/notification.service';\r\nimport { ImageCutterService } from '../../api/services/image.cutter.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  {}\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\r\n  file: File | null = null;\r\n  existeLogo = false;\r\n  selectedImage: string = '';\r\n\r\n  imageUrl = input<string>(this.imageService.userDefaultImage());\r\n  imageSource = signal<string>(this.imageService.userDefaultImage());\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.imageSource.set(this.imageUrl());\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    } 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                  );\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    const msg = '<p>Você tem certeza que deseja retirar a foto desse usuário?</p>';\r\n\r\n    this.notificationService.question({\r\n      type: 'question',\r\n      message: msg,\r\n      accept: (data:any) =>\r\n      {\r\n        this.removerFoto()\r\n      },\r\n      reject: (data:any) => {\r\n\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 class=\"image-container\" [style.width.px]=\"width\" [style.height.px]=\"height\" >\r\n\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\r\n  <div class=\"btn\">\r\n    <input #fileInput *ngIf=\"btnAlterarFoto\" id=\"fotoEscolhida\" type=\"file\" accept=\"image/*\" style=\"display:none\" (change)=\"changeImage($any($event))\">\r\n\r\n    <button *ngIf=\"btnAlterarFoto && !existeLogo\"\r\n      class=\"botao-alterar-foto border-circle\"\r\n      [style.background-color]=\"btnsColor\" (click)=\"openFile()\">\r\n      <i class=\"material-symbols-outlined\">photo_camera</i>\r\n    </button>\r\n\r\n    <button *ngIf=\"btnAlterarFoto && existeLogo\" [style.background-color]=\"btnsColor\"\r\n        class=\"botao-excluir-foto border-circle\r\n                hover:shadow-3\r\n                active:shadow-5\"\r\n        (click)=\"questionRemoverFoto()\">\r\n      <i class=\"material-symbols-outlined\">delete</i>\r\n    </button>\r\n  </div>\r\n\r\n  <ngx-loading [show]=\"!imageLoaded()\" full class=\"container-foto\" [config]=\"{backdropBorderRadius: '100%', fullScreenBackdrop: false }\"></ngx-loading>\r\n\r\n</div>\r\n"]}
127
+ //# 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  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 { NotificationService } from '../../api/services/notification.service';\r\nimport { ImageCutterService } from '../../api/services/image.cutter.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  {}\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\r\n  file: File | null = null;\r\n  existeLogo = false;\r\n  selectedImage: string = '';\r\n\r\n  imageUrl = input<string>(this.imageService.userDefaultImage());\r\n  imageSource = signal<string>(this.imageService.userDefaultImage());\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.imageSource.set(this.imageUrl());\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    } 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    \r\n        this.removerFoto()\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 class=\"image-container\" [style.width.px]=\"width\" [style.height.px]=\"height\" >\r\n\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\r\n  <div class=\"btn\">\r\n    <input #fileInput *ngIf=\"btnAlterarFoto\" id=\"fotoEscolhida\" type=\"file\" accept=\"image/*\" style=\"display:none\" (change)=\"changeImage($any($event))\">\r\n\r\n    <button *ngIf=\"btnAlterarFoto && !existeLogo\"\r\n      class=\"botao-alterar-foto border-circle\"\r\n      [style.background-color]=\"btnsColor\" (click)=\"openFile()\">\r\n      <i class=\"material-symbols-outlined\">photo_camera</i>\r\n    </button>\r\n\r\n    <button *ngIf=\"btnAlterarFoto && existeLogo\" [style.background-color]=\"btnsColor\"\r\n        class=\"botao-excluir-foto border-circle\r\n                hover:shadow-3\r\n                active:shadow-5\"\r\n        (click)=\"questionRemoverFoto()\">\r\n      <i class=\"material-symbols-outlined\">delete</i>\r\n    </button>\r\n  </div>\r\n\r\n  <ngx-loading [show]=\"!imageLoaded()\" full class=\"container-foto\" [config]=\"{backdropBorderRadius: '100%', fullScreenBackdrop: false }\"></ngx-loading>\r\n\r\n</div>\r\n"]}
@@ -32,12 +32,10 @@ export class KvCardSelectionComponent {
32
32
  });
33
33
  this.filteredMasters.set(this.masters());
34
34
  window.addEventListener('resize', () => {
35
- console.log(window.innerWidth, 'uai');
36
35
  this.widthScreen.set(window.innerWidth);
37
36
  });
38
37
  }
39
38
  selectMaster(master) {
40
- console.log(master, 'naster');
41
39
  this.onSelectMaster.emit(master);
42
40
  }
43
41
  buscarMasters() {
@@ -48,10 +46,10 @@ export class KvCardSelectionComponent {
48
46
  }));
49
47
  }
50
48
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvCardSelectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
51
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvCardSelectionComponent, selector: "kv-card-selection", inputs: { masters: { classPropertyName: "masters", publicName: "masters", isSignal: true, isRequired: false, transformFunction: null }, emptyText: { classPropertyName: "emptyText", publicName: "emptyText", isSignal: true, isRequired: false, transformFunction: null }, logo: { classPropertyName: "logo", publicName: "logo", isSignal: true, isRequired: false, transformFunction: null }, nomeUsuario: { classPropertyName: "nomeUsuario", publicName: "nomeUsuario", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onSelectMaster: "onSelectMaster", onFilter: "onFilter" }, ngImport: i0, template: "<div\r\n class=\"bg-white h-auto border-round-lg lg:p-3 p-1 flex flex-column gap-2\"\r\n [style.max-width.rem]=\"'45'\"\r\n [style.min-width]=\"minWidthCard()\"\r\n>\r\n <div class=\"px-2 flex flex-column align-items-center gap-2\">\r\n <img [src]=\"logo()\" style=\"height: 4rem\" class=\" py-2\" />\r\n <span class=\"text-sm\">\r\n Ol\u00E1, <b>{{ nomeUsuario() }}</b\r\n >. Bem vindo (a)! Escolha a <b>Licen\u00E7a</b> que deseja acessar:\r\n </span>\r\n </div>\r\n\r\n @if(masters().length > 6) {\r\n <div\r\n class=\"col-12 grid formgrid p-fluid m-0 px-2 pt-2 pb-0\"\r\n [formGroup]=\"workspaceForm\"\r\n >\r\n <kv-input-text\r\n placeholder=\"Buscar licen\u00E7a\"\r\n class=\"col-12 m-0 p-0\"\r\n (onInput)=\"buscarMasters()\"\r\n formControlName=\"search\"\r\n ></kv-input-text>\r\n </div>\r\n }\r\n\r\n <div\r\n class=\"grid m-0 border-round-lg gap-2 p-2 {{\r\n filteredMasters().length > 6 && 'overflow-y-auto'\r\n }} max-h-24rem cards-container\"\r\n >\r\n @for(master of filteredMasters(); track $index) {\r\n <div\r\n class=\"{{\r\n $index % 2 == 0 ? 'sm:col-6 col-12' : 'sm:col col-12'\r\n }} p-0 card-option\"\r\n (click)=\"selectMaster(master)\"\r\n >\r\n <div class=\"flex flex-column gap-3 p-3\">\r\n <div class=\"flex flex-row align-items-center gap-1 font-semibold\">\r\n <span class=\"material-symbols-outlined text-md\"> verified </span>\r\n <span class=\"text-sm\">{{\r\n isEmpresa()(master.cpfcnpj) ? \"CNPJ:\" : \"CPF:\"\r\n }}</span>\r\n <span class=\"text-sm\">{{ transformCpfCnpj()(master.cpfcnpj) }}</span>\r\n </div>\r\n\r\n <span style=\"word-break: break-word text-medium\" class=\"text-sm\">{{\r\n master.nome\r\n }}</span>\r\n </div>\r\n </div>\r\n } @if(filteredMasters().length == 0) {\r\n <p>{{ emptyText() }}</p>\r\n }\r\n </div>\r\n</div>\r\n", styles: [".card-option{background-color:#fff;border-radius:.5rem;border:1px solid #eaeaea;height:7.5rem;overflow:hidden;transition:all .2s ease-in-out;cursor:pointer}.card-option:hover{border:1px solid #581999;background-color:#d0b3dd4d}.card-option:hover span{color:#581999}.card-option:active{background-color:#d0b3dd99}.cards-container::-webkit-scrollbar{width:6px}.cards-container::-webkit-scrollbar:hover{background-color:#dededebf}.cards-container::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}.cards-container:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}.cards-container::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}span{color:#64748b}\n"], dependencies: [{ kind: "component", type: i1.KvInputTextComponent, selector: "kv-input-text", inputs: ["textCaptalized"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] }); }
49
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvCardSelectionComponent, selector: "kv-card-selection", inputs: { masters: { classPropertyName: "masters", publicName: "masters", isSignal: true, isRequired: false, transformFunction: null }, emptyText: { classPropertyName: "emptyText", publicName: "emptyText", isSignal: true, isRequired: false, transformFunction: null }, logo: { classPropertyName: "logo", publicName: "logo", isSignal: true, isRequired: false, transformFunction: null }, nomeUsuario: { classPropertyName: "nomeUsuario", publicName: "nomeUsuario", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onSelectMaster: "onSelectMaster", onFilter: "onFilter" }, ngImport: i0, template: "<div\r\n class=\"bg-white h-auto border-round-lg lg:p-3 p-1 flex flex-column gap-2\"\r\n [style.max-width.rem]=\"'45'\"\r\n [style.min-width]=\"minWidthCard()\"\r\n>\r\n <div class=\"px-2 flex flex-column align-items-center gap-2\">\r\n <img [src]=\"logo()\" style=\"height: 4rem\" class=\" py-2\" />\r\n <span class=\"text-sm\">\r\n Ol\u00E1, <b>{{ nomeUsuario() }}</b\r\n >. Bem vindo (a)! Escolha a <b>Licen\u00E7a</b> que deseja acessar:\r\n </span>\r\n </div>\r\n\r\n @if(masters().length > 6) {\r\n <div\r\n class=\"col-12 grid formgrid p-fluid m-0 px-2 pt-2 pb-0\"\r\n [formGroup]=\"workspaceForm\"\r\n >\r\n <kv-input-text\r\n placeholder=\"Buscar licen\u00E7a\"\r\n class=\"col-12 m-0 p-0\"\r\n (onInput)=\"buscarMasters()\"\r\n formControlName=\"search\"\r\n ></kv-input-text>\r\n </div>\r\n }\r\n\r\n <div\r\n class=\"grid m-0 border-round-lg gap-2 p-2 {{\r\n (filteredMasters().length > 6 || this.widthScreen() < 992) && 'overflow-y-auto'\r\n }} max-h-24rem cards-container\"\r\n >\r\n @for(master of filteredMasters(); track $index) {\r\n <div\r\n class=\"{{\r\n $index % 2 == 0 ? 'sm:col-6 col-12' : 'sm:col col-12'\r\n }} p-0 card-option\"\r\n (click)=\"selectMaster(master)\"\r\n >\r\n <div class=\"flex flex-column gap-3 p-3\">\r\n <div class=\"flex flex-row align-items-center gap-1 font-semibold\">\r\n <span class=\"material-symbols-outlined text-md\"> verified </span>\r\n <span class=\"text-sm\">{{\r\n isEmpresa()(master.cpfcnpj) ? \"CNPJ:\" : \"CPF:\"\r\n }}</span>\r\n <span class=\"text-sm\">{{ transformCpfCnpj()(master.cpfcnpj) }}</span>\r\n </div>\r\n\r\n <span style=\"word-break: break-word text-medium\" class=\"text-sm\">{{\r\n master.nome\r\n }}</span>\r\n </div>\r\n </div>\r\n } @if(filteredMasters().length == 0) {\r\n <p>{{ emptyText() }}</p>\r\n }\r\n </div>\r\n</div>\r\n", styles: [".card-option{background-color:#fff;border-radius:.5rem;border:1px solid #eaeaea;height:7.5rem;overflow:hidden;transition:all .2s ease-in-out;cursor:pointer}.card-option:hover{border:1px solid #581999;background-color:#d0b3dd4d}.card-option:hover span{color:#581999}.card-option:active{background-color:#d0b3dd99}.cards-container::-webkit-scrollbar{width:6px}.cards-container::-webkit-scrollbar:hover{background-color:#dededebf}.cards-container::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}.cards-container:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}.cards-container::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}span{color:#64748b}\n"], dependencies: [{ kind: "component", type: i1.KvInputTextComponent, selector: "kv-input-text", inputs: ["textCaptalized"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] }); }
52
50
  }
53
51
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvCardSelectionComponent, decorators: [{
54
52
  type: Component,
55
- args: [{ selector: 'kv-card-selection', standalone: false, template: "<div\r\n class=\"bg-white h-auto border-round-lg lg:p-3 p-1 flex flex-column gap-2\"\r\n [style.max-width.rem]=\"'45'\"\r\n [style.min-width]=\"minWidthCard()\"\r\n>\r\n <div class=\"px-2 flex flex-column align-items-center gap-2\">\r\n <img [src]=\"logo()\" style=\"height: 4rem\" class=\" py-2\" />\r\n <span class=\"text-sm\">\r\n Ol\u00E1, <b>{{ nomeUsuario() }}</b\r\n >. Bem vindo (a)! Escolha a <b>Licen\u00E7a</b> que deseja acessar:\r\n </span>\r\n </div>\r\n\r\n @if(masters().length > 6) {\r\n <div\r\n class=\"col-12 grid formgrid p-fluid m-0 px-2 pt-2 pb-0\"\r\n [formGroup]=\"workspaceForm\"\r\n >\r\n <kv-input-text\r\n placeholder=\"Buscar licen\u00E7a\"\r\n class=\"col-12 m-0 p-0\"\r\n (onInput)=\"buscarMasters()\"\r\n formControlName=\"search\"\r\n ></kv-input-text>\r\n </div>\r\n }\r\n\r\n <div\r\n class=\"grid m-0 border-round-lg gap-2 p-2 {{\r\n filteredMasters().length > 6 && 'overflow-y-auto'\r\n }} max-h-24rem cards-container\"\r\n >\r\n @for(master of filteredMasters(); track $index) {\r\n <div\r\n class=\"{{\r\n $index % 2 == 0 ? 'sm:col-6 col-12' : 'sm:col col-12'\r\n }} p-0 card-option\"\r\n (click)=\"selectMaster(master)\"\r\n >\r\n <div class=\"flex flex-column gap-3 p-3\">\r\n <div class=\"flex flex-row align-items-center gap-1 font-semibold\">\r\n <span class=\"material-symbols-outlined text-md\"> verified </span>\r\n <span class=\"text-sm\">{{\r\n isEmpresa()(master.cpfcnpj) ? \"CNPJ:\" : \"CPF:\"\r\n }}</span>\r\n <span class=\"text-sm\">{{ transformCpfCnpj()(master.cpfcnpj) }}</span>\r\n </div>\r\n\r\n <span style=\"word-break: break-word text-medium\" class=\"text-sm\">{{\r\n master.nome\r\n }}</span>\r\n </div>\r\n </div>\r\n } @if(filteredMasters().length == 0) {\r\n <p>{{ emptyText() }}</p>\r\n }\r\n </div>\r\n</div>\r\n", styles: [".card-option{background-color:#fff;border-radius:.5rem;border:1px solid #eaeaea;height:7.5rem;overflow:hidden;transition:all .2s ease-in-out;cursor:pointer}.card-option:hover{border:1px solid #581999;background-color:#d0b3dd4d}.card-option:hover span{color:#581999}.card-option:active{background-color:#d0b3dd99}.cards-container::-webkit-scrollbar{width:6px}.cards-container::-webkit-scrollbar:hover{background-color:#dededebf}.cards-container::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}.cards-container:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}.cards-container::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}span{color:#64748b}\n"] }]
53
+ args: [{ selector: 'kv-card-selection', standalone: false, template: "<div\r\n class=\"bg-white h-auto border-round-lg lg:p-3 p-1 flex flex-column gap-2\"\r\n [style.max-width.rem]=\"'45'\"\r\n [style.min-width]=\"minWidthCard()\"\r\n>\r\n <div class=\"px-2 flex flex-column align-items-center gap-2\">\r\n <img [src]=\"logo()\" style=\"height: 4rem\" class=\" py-2\" />\r\n <span class=\"text-sm\">\r\n Ol\u00E1, <b>{{ nomeUsuario() }}</b\r\n >. Bem vindo (a)! Escolha a <b>Licen\u00E7a</b> que deseja acessar:\r\n </span>\r\n </div>\r\n\r\n @if(masters().length > 6) {\r\n <div\r\n class=\"col-12 grid formgrid p-fluid m-0 px-2 pt-2 pb-0\"\r\n [formGroup]=\"workspaceForm\"\r\n >\r\n <kv-input-text\r\n placeholder=\"Buscar licen\u00E7a\"\r\n class=\"col-12 m-0 p-0\"\r\n (onInput)=\"buscarMasters()\"\r\n formControlName=\"search\"\r\n ></kv-input-text>\r\n </div>\r\n }\r\n\r\n <div\r\n class=\"grid m-0 border-round-lg gap-2 p-2 {{\r\n (filteredMasters().length > 6 || this.widthScreen() < 992) && 'overflow-y-auto'\r\n }} max-h-24rem cards-container\"\r\n >\r\n @for(master of filteredMasters(); track $index) {\r\n <div\r\n class=\"{{\r\n $index % 2 == 0 ? 'sm:col-6 col-12' : 'sm:col col-12'\r\n }} p-0 card-option\"\r\n (click)=\"selectMaster(master)\"\r\n >\r\n <div class=\"flex flex-column gap-3 p-3\">\r\n <div class=\"flex flex-row align-items-center gap-1 font-semibold\">\r\n <span class=\"material-symbols-outlined text-md\"> verified </span>\r\n <span class=\"text-sm\">{{\r\n isEmpresa()(master.cpfcnpj) ? \"CNPJ:\" : \"CPF:\"\r\n }}</span>\r\n <span class=\"text-sm\">{{ transformCpfCnpj()(master.cpfcnpj) }}</span>\r\n </div>\r\n\r\n <span style=\"word-break: break-word text-medium\" class=\"text-sm\">{{\r\n master.nome\r\n }}</span>\r\n </div>\r\n </div>\r\n } @if(filteredMasters().length == 0) {\r\n <p>{{ emptyText() }}</p>\r\n }\r\n </div>\r\n</div>\r\n", styles: [".card-option{background-color:#fff;border-radius:.5rem;border:1px solid #eaeaea;height:7.5rem;overflow:hidden;transition:all .2s ease-in-out;cursor:pointer}.card-option:hover{border:1px solid #581999;background-color:#d0b3dd4d}.card-option:hover span{color:#581999}.card-option:active{background-color:#d0b3dd99}.cards-container::-webkit-scrollbar{width:6px}.cards-container::-webkit-scrollbar:hover{background-color:#dededebf}.cards-container::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}.cards-container:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}.cards-container::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}span{color:#64748b}\n"] }]
56
54
  }] });
57
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-card-selection.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-card-selection/kv-card-selection.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-card-selection/kv-card-selection.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, effect, inject, input, output, signal } from '@angular/core';\r\nimport { CpfCnpjPipe } from '../../api/pipes/cpfcnpj.pipe';\r\nimport { FormBuilder, FormGroup } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'kv-card-selection',\r\n  standalone: false,\r\n  templateUrl: './kv-card-selection.component.html',\r\n  styleUrl: './kv-card-selection.component.scss'\r\n})\r\nexport class KvCardSelectionComponent {\r\n\r\n  masters = input<any>();\r\n\r\n  widthScreen = signal<number>(window.innerWidth);\r\n\r\n  filteredMasters = signal<any>([]);\r\n\r\n  emptyText = input<string>('Nenhum resultado encontrado');\r\n\r\n  logo = input<string>('https://work-assets.keevo.com.br/img/logo-keevocenter.png');\r\n  nomeUsuario = input<string>('');\r\n\r\n  onSelectMaster = output<any>();\r\n  onFilter = output<any>();\r\n\r\n  cpfCnpjPipe = inject(CpfCnpjPipe);\r\n  fb = inject(FormBuilder);\r\n\r\n  workspaceForm!: FormGroup;\r\n\r\n  transformCpfCnpj = computed(() => (cpfCnpj: string) => {\r\n    return this.cpfCnpjPipe.transform(cpfCnpj);\r\n  });\r\n\r\n  isEmpresa = computed(() => (cpfCnpj: string) => {\r\n    return cpfCnpj.length > 11;\r\n  })\r\n\r\n  minWidthCard = computed(() => {\r\n    return this.widthScreen() >= 992 ? '45rem' : '100%';\r\n  });\r\n\r\n  ngOnInit() {\r\n    this.workspaceForm = this.fb.group({\r\n      search: ['']\r\n    });\r\n\r\n    this.filteredMasters.set(this.masters());\r\n\r\n    window.addEventListener('resize', () => {\r\n      console.log(window.innerWidth, 'uai');\r\n      this.widthScreen.set(window.innerWidth);\r\n    });\r\n  }\r\n\r\n  selectMaster(master: any) {\r\n    console.log(master, 'naster')\r\n    this.onSelectMaster.emit(master);\r\n  }\r\n\r\n  buscarMasters() {\r\n    this.onFilter.emit(this.workspaceForm.value.search);\r\n    const searchValue = this.workspaceForm.value.search.toLowerCase();\r\n    this.filteredMasters.set(this.masters().filter((master: any) => {\r\n      return master.cpfcnpj.includes(searchValue) || master.nome.toLowerCase().includes(searchValue);\r\n    }));\r\n  }\r\n}\r\n","<div\r\n  class=\"bg-white h-auto border-round-lg lg:p-3 p-1 flex flex-column gap-2\"\r\n  [style.max-width.rem]=\"'45'\"\r\n  [style.min-width]=\"minWidthCard()\"\r\n>\r\n  <div class=\"px-2 flex flex-column align-items-center gap-2\">\r\n    <img [src]=\"logo()\" style=\"height: 4rem\" class=\" py-2\" />\r\n    <span class=\"text-sm\">\r\n      Olá, <b>{{ nomeUsuario() }}</b\r\n      >. Bem vindo (a)! Escolha a <b>Licença</b> que deseja acessar:\r\n    </span>\r\n  </div>\r\n\r\n  @if(masters().length > 6) {\r\n  <div\r\n    class=\"col-12 grid formgrid p-fluid m-0 px-2 pt-2 pb-0\"\r\n    [formGroup]=\"workspaceForm\"\r\n  >\r\n    <kv-input-text\r\n      placeholder=\"Buscar licença\"\r\n      class=\"col-12 m-0 p-0\"\r\n      (onInput)=\"buscarMasters()\"\r\n      formControlName=\"search\"\r\n    ></kv-input-text>\r\n  </div>\r\n  }\r\n\r\n  <div\r\n    class=\"grid m-0 border-round-lg gap-2 p-2 {{\r\n      filteredMasters().length > 6 && 'overflow-y-auto'\r\n    }} max-h-24rem cards-container\"\r\n  >\r\n    @for(master of filteredMasters(); track $index) {\r\n    <div\r\n      class=\"{{\r\n        $index % 2 == 0 ? 'sm:col-6 col-12' : 'sm:col col-12'\r\n      }} p-0 card-option\"\r\n      (click)=\"selectMaster(master)\"\r\n    >\r\n      <div class=\"flex flex-column gap-3 p-3\">\r\n        <div class=\"flex flex-row align-items-center gap-1 font-semibold\">\r\n          <span class=\"material-symbols-outlined text-md\"> verified </span>\r\n          <span class=\"text-sm\">{{\r\n            isEmpresa()(master.cpfcnpj) ? \"CNPJ:\" : \"CPF:\"\r\n          }}</span>\r\n          <span class=\"text-sm\">{{ transformCpfCnpj()(master.cpfcnpj) }}</span>\r\n        </div>\r\n\r\n        <span style=\"word-break: break-word text-medium\" class=\"text-sm\">{{\r\n          master.nome\r\n        }}</span>\r\n      </div>\r\n    </div>\r\n    } @if(filteredMasters().length == 0) {\r\n    <p>{{ emptyText() }}</p>\r\n    }\r\n  </div>\r\n</div>\r\n"]}
55
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-card-selection.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-card-selection/kv-card-selection.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-card-selection/kv-card-selection.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAU,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAC3D,OAAO,EAAE,WAAW,EAAa,MAAM,gBAAgB,CAAC;;;;AAQxD,MAAM,OAAO,wBAAwB;IANrC;QAQE,YAAO,GAAG,KAAK,EAAO,CAAC;QAEvB,gBAAW,GAAG,MAAM,CAAS,MAAM,CAAC,UAAU,CAAC,CAAC;QAEhD,oBAAe,GAAG,MAAM,CAAM,EAAE,CAAC,CAAC;QAElC,cAAS,GAAG,KAAK,CAAS,6BAA6B,CAAC,CAAC;QAEzD,SAAI,GAAG,KAAK,CAAS,2DAA2D,CAAC,CAAC;QAClF,gBAAW,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QAEhC,mBAAc,GAAG,MAAM,EAAO,CAAC;QAC/B,aAAQ,GAAG,MAAM,EAAO,CAAC;QAEzB,gBAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAClC,OAAE,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAIzB,qBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,OAAe,EAAE,EAAE;YACpD,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QAC7C,CAAC,CAAC,CAAC;QAEH,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,OAAe,EAAE,EAAE;YAC7C,OAAO,OAAO,CAAC,MAAM,GAAG,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAA;QAEF,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC3B,OAAO,IAAI,CAAC,WAAW,EAAE,IAAI,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;QACtD,CAAC,CAAC,CAAC;KAyBJ;IAvBC,QAAQ;QACN,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YACjC,MAAM,EAAE,CAAC,EAAE,CAAC;SACb,CAAC,CAAC;QAEH,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QAEzC,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,GAAG,EAAE;YACrC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAC1C,CAAC,CAAC,CAAC;IACL,CAAC;IAED,YAAY,CAAC,MAAW;QACtB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;IAED,aAAa;QACX,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACpD,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;QAClE,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM,CAAC,CAAC,MAAW,EAAE,EAAE;YAC7D,OAAO,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;QACjG,CAAC,CAAC,CAAC,CAAC;IACN,CAAC;8GAvDU,wBAAwB;kGAAxB,wBAAwB,2oBCVrC,y+DA0DA;;2FDhDa,wBAAwB;kBANpC,SAAS;+BACE,mBAAmB,cACjB,KAAK","sourcesContent":["import { Component, computed, effect, inject, input, output, signal } from '@angular/core';\r\nimport { CpfCnpjPipe } from '../../api/pipes/cpfcnpj.pipe';\r\nimport { FormBuilder, FormGroup } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'kv-card-selection',\r\n  standalone: false,\r\n  templateUrl: './kv-card-selection.component.html',\r\n  styleUrl: './kv-card-selection.component.scss'\r\n})\r\nexport class KvCardSelectionComponent {\r\n\r\n  masters = input<any>();\r\n\r\n  widthScreen = signal<number>(window.innerWidth);\r\n\r\n  filteredMasters = signal<any>([]);\r\n\r\n  emptyText = input<string>('Nenhum resultado encontrado');\r\n\r\n  logo = input<string>('https://work-assets.keevo.com.br/img/logo-keevocenter.png');\r\n  nomeUsuario = input<string>('');\r\n\r\n  onSelectMaster = output<any>();\r\n  onFilter = output<any>();\r\n\r\n  cpfCnpjPipe = inject(CpfCnpjPipe);\r\n  fb = inject(FormBuilder);\r\n\r\n  workspaceForm!: FormGroup;\r\n\r\n  transformCpfCnpj = computed(() => (cpfCnpj: string) => {\r\n    return this.cpfCnpjPipe.transform(cpfCnpj);\r\n  });\r\n\r\n  isEmpresa = computed(() => (cpfCnpj: string) => {\r\n    return cpfCnpj.length > 11;\r\n  })\r\n\r\n  minWidthCard = computed(() => {\r\n    return this.widthScreen() >= 992 ? '45rem' : '100%';\r\n  });\r\n\r\n  ngOnInit() {\r\n    this.workspaceForm = this.fb.group({\r\n      search: ['']\r\n    });\r\n\r\n    this.filteredMasters.set(this.masters());\r\n\r\n    window.addEventListener('resize', () => {\r\n      this.widthScreen.set(window.innerWidth);\r\n    });\r\n  }\r\n\r\n  selectMaster(master: any) {\r\n    this.onSelectMaster.emit(master);\r\n  }\r\n\r\n  buscarMasters() {\r\n    this.onFilter.emit(this.workspaceForm.value.search);\r\n    const searchValue = this.workspaceForm.value.search.toLowerCase();\r\n    this.filteredMasters.set(this.masters().filter((master: any) => {\r\n      return master.cpfcnpj.includes(searchValue) || master.nome.toLowerCase().includes(searchValue);\r\n    }));\r\n  }\r\n}\r\n","<div\r\n  class=\"bg-white h-auto border-round-lg lg:p-3 p-1 flex flex-column gap-2\"\r\n  [style.max-width.rem]=\"'45'\"\r\n  [style.min-width]=\"minWidthCard()\"\r\n>\r\n  <div class=\"px-2 flex flex-column align-items-center gap-2\">\r\n    <img [src]=\"logo()\" style=\"height: 4rem\" class=\" py-2\" />\r\n    <span class=\"text-sm\">\r\n      Olá, <b>{{ nomeUsuario() }}</b\r\n      >. Bem vindo (a)! Escolha a <b>Licença</b> que deseja acessar:\r\n    </span>\r\n  </div>\r\n\r\n  @if(masters().length > 6) {\r\n  <div\r\n    class=\"col-12 grid formgrid p-fluid m-0 px-2 pt-2 pb-0\"\r\n    [formGroup]=\"workspaceForm\"\r\n  >\r\n    <kv-input-text\r\n      placeholder=\"Buscar licença\"\r\n      class=\"col-12 m-0 p-0\"\r\n      (onInput)=\"buscarMasters()\"\r\n      formControlName=\"search\"\r\n    ></kv-input-text>\r\n  </div>\r\n  }\r\n\r\n  <div\r\n    class=\"grid m-0 border-round-lg gap-2 p-2 {{\r\n      (filteredMasters().length > 6 || this.widthScreen() < 992) && 'overflow-y-auto'\r\n    }} max-h-24rem cards-container\"\r\n  >\r\n    @for(master of filteredMasters(); track $index) {\r\n    <div\r\n      class=\"{{\r\n        $index % 2 == 0 ? 'sm:col-6 col-12' : 'sm:col col-12'\r\n      }} p-0 card-option\"\r\n      (click)=\"selectMaster(master)\"\r\n    >\r\n      <div class=\"flex flex-column gap-3 p-3\">\r\n        <div class=\"flex flex-row align-items-center gap-1 font-semibold\">\r\n          <span class=\"material-symbols-outlined text-md\"> verified </span>\r\n          <span class=\"text-sm\">{{\r\n            isEmpresa()(master.cpfcnpj) ? \"CNPJ:\" : \"CPF:\"\r\n          }}</span>\r\n          <span class=\"text-sm\">{{ transformCpfCnpj()(master.cpfcnpj) }}</span>\r\n        </div>\r\n\r\n        <span style=\"word-break: break-word text-medium\" class=\"text-sm\">{{\r\n          master.nome\r\n        }}</span>\r\n      </div>\r\n    </div>\r\n    } @if(filteredMasters().length == 0) {\r\n    <p>{{ emptyText() }}</p>\r\n    }\r\n  </div>\r\n</div>\r\n"]}
@@ -4266,9 +4266,9 @@ class ImageCutterService {
4266
4266
  constructor(dialogservice) {
4267
4267
  this.dialogservice = dialogservice;
4268
4268
  }
4269
- cut(imageBase64, width, height, indCircle = false) {
4269
+ cut(imageBase64, width, height, indCircle = false, avatar) {
4270
4270
  const cutConfig = { imageBase64, width, height, indCircle };
4271
- this.abrirModal(cutConfig);
4271
+ this.abrirModal(cutConfig, avatar);
4272
4272
  return new Promise((resolve, reject) => {
4273
4273
  window.addEventListener('cropImage', (event) => {
4274
4274
  if (event.detail.status == true) {
@@ -4280,15 +4280,19 @@ class ImageCutterService {
4280
4280
  });
4281
4281
  });
4282
4282
  }
4283
- abrirModal(cutConfig) {
4283
+ abrirModal(cutConfig, avatar) {
4284
+ let quality = 100;
4285
+ if (avatar) {
4286
+ quality = 80;
4287
+ }
4284
4288
  const params = {
4285
4289
  closable: true,
4286
4290
  maximizable: false,
4287
4291
  popup: true,
4288
4292
  width: '75vw',
4289
4293
  header: `Cortar`,
4290
- id: { imagem: cutConfig.imageBase64, width: cutConfig.width, height: cutConfig.height, indCircle: cutConfig.indCircle },
4291
- styleClass: 'modal'
4294
+ id: { imagem: cutConfig.imageBase64, width: cutConfig.width, height: cutConfig.height, indCircle: cutConfig.indCircle, quality: quality },
4295
+ styleClass: 'modal',
4292
4296
  };
4293
4297
  const dialogRef = FormService.openDialog(this.dialogservice, SimpleComponent, () => { }, params);
4294
4298
  }
@@ -4300,11 +4304,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
4300
4304
  args: [{ providedIn: 'root' }]
4301
4305
  }], ctorParameters: () => [{ type: i1$3.DialogService }] });
4302
4306
  class SimpleComponent {
4303
- constructor(dynamicDialogRef, dialogService) {
4307
+ constructor(dynamicDialogRef, dialogService, dynamicDialogConfig) {
4304
4308
  this.dynamicDialogRef = dynamicDialogRef;
4305
4309
  this.dialogService = dialogService;
4310
+ this.dynamicDialogConfig = dynamicDialogConfig;
4306
4311
  this.imageChangedEvent = null;
4307
4312
  this.croppedImage = '';
4313
+ this.quality = this.dynamicDialogConfig.data.id.quality;
4308
4314
  //#region Variáveis de controle
4309
4315
  this._variaviesDialog = signal(null);
4310
4316
  this.aspectRatio = signal(1 / 1);
@@ -4363,7 +4369,7 @@ class SimpleComponent {
4363
4369
  } }));
4364
4370
  this.closeCropModal();
4365
4371
  }
4366
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: SimpleComponent, deps: [{ token: i1$3.DynamicDialogRef }, { token: i1$3.DialogService }], target: i0.ɵɵFactoryTarget.Component }); }
4372
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: SimpleComponent, deps: [{ token: i1$3.DynamicDialogRef }, { token: i1$3.DialogService }, { token: i1$3.DynamicDialogConfig }], target: i0.ɵɵFactoryTarget.Component }); }
4367
4373
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: SimpleComponent, isStandalone: true, selector: "app-simple-component", ngImport: i0, template: `
4368
4374
  <div class="modal-content">
4369
4375
 
@@ -4376,7 +4382,7 @@ class SimpleComponent {
4376
4382
  (loadImageFailed)="loadImageFailed()"
4377
4383
  [roundCropper]="this._variaviesDialog()?.indCircle"
4378
4384
  [maintainAspectRatio]="true"
4379
- [imageQuality]="100"
4385
+ [imageQuality]="quality"
4380
4386
  format="jpeg"
4381
4387
  output='base64'
4382
4388
  alignImage="center"
@@ -4407,7 +4413,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
4407
4413
  (loadImageFailed)="loadImageFailed()"
4408
4414
  [roundCropper]="this._variaviesDialog()?.indCircle"
4409
4415
  [maintainAspectRatio]="true"
4410
- [imageQuality]="100"
4416
+ [imageQuality]="quality"
4411
4417
  format="jpeg"
4412
4418
  output='base64'
4413
4419
  alignImage="center"
@@ -4432,7 +4438,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
4432
4438
  KvLabelModule,
4433
4439
  ImageCropperComponent
4434
4440
  ], styles: ["img{border-style:solid;border-width:2px;border-radius:50%;object-fit:cover}i{font-size:22px}.botao-alterar-foto{border-style:none;width:max-content;background-color:#002542;color:#000;font-weight:700;cursor:pointer;padding:7px 9px}.botao-alterar-foto i{color:#fff}.botao-excluir-foto{border-style:none;width:max-content;background-color:#002542;color:#000;font-weight:700;cursor:pointer;padding:7px 9px}.botao-excluir-foto i{color:#fff}.btn{position:absolute;top:87%;left:87%;transform:translate(-50%,-50%)}.image-container{display:inline-block;position:relative}.modal-content{height:60vh;position:relative;background-color:#fefefe;margin:1% auto;padding:20px;width:80%;max-width:fit-content;text-align:center;border-radius:12px;display:flex;align-items:center;justify-content:center}.crop-container{display:flex;justify-content:center;align-items:center}.crop-canvas{border:1px solid #d1d5db;border-radius:12px;width:100%;height:auto}.crop-border{position:absolute;border:2px dashed #9ca3af;pointer-events:none}.zoom-container{padding-top:20px;padding-bottom:20px}.button-container{display:flex;align-items:center;justify-content:flex-end;flex-direction:row;margin-top:24px;position:fixed;bottom:0;background:#fff;width:90%;padding:15px}\n"] }]
4435
- }], ctorParameters: () => [{ type: i1$3.DynamicDialogRef }, { type: i1$3.DialogService }] });
4441
+ }], ctorParameters: () => [{ type: i1$3.DynamicDialogRef }, { type: i1$3.DialogService }, { type: i1$3.DynamicDialogConfig }] });
4436
4442
 
4437
4443
  class KvAvatarComponent {
4438
4444
  constructor(imageService, notificationService, imageCutterService) {
@@ -4488,7 +4494,7 @@ class KvAvatarComponent {
4488
4494
  const reader = new FileReader();
4489
4495
  reader.onload = async () => {
4490
4496
  try {
4491
- const result = await this.imageCutterService.cut(reader.result?.toString() ?? '', this.width, this.height, true);
4497
+ const result = await this.imageCutterService.cut(reader.result?.toString() ?? '', this.width, this.height, true, true);
4492
4498
  this.existeLogo = true;
4493
4499
  this.imageSource.set(result);
4494
4500
  this.selectedImage = result;
@@ -4516,16 +4522,7 @@ class KvAvatarComponent {
4516
4522
  }
4517
4523
  }
4518
4524
  questionRemoverFoto() {
4519
- const msg = '<p>Você tem certeza que deseja retirar a foto desse usuário?</p>';
4520
- this.notificationService.question({
4521
- type: 'question',
4522
- message: msg,
4523
- accept: (data) => {
4524
- this.removerFoto();
4525
- },
4526
- reject: (data) => {
4527
- }
4528
- });
4525
+ this.removerFoto();
4529
4526
  }
4530
4527
  removerFoto() {
4531
4528
  this.imageSource.set('');
@@ -8786,12 +8783,10 @@ class KvCardSelectionComponent {
8786
8783
  });
8787
8784
  this.filteredMasters.set(this.masters());
8788
8785
  window.addEventListener('resize', () => {
8789
- console.log(window.innerWidth, 'uai');
8790
8786
  this.widthScreen.set(window.innerWidth);
8791
8787
  });
8792
8788
  }
8793
8789
  selectMaster(master) {
8794
- console.log(master, 'naster');
8795
8790
  this.onSelectMaster.emit(master);
8796
8791
  }
8797
8792
  buscarMasters() {
@@ -8802,11 +8797,11 @@ class KvCardSelectionComponent {
8802
8797
  }));
8803
8798
  }
8804
8799
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvCardSelectionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
8805
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvCardSelectionComponent, selector: "kv-card-selection", inputs: { masters: { classPropertyName: "masters", publicName: "masters", isSignal: true, isRequired: false, transformFunction: null }, emptyText: { classPropertyName: "emptyText", publicName: "emptyText", isSignal: true, isRequired: false, transformFunction: null }, logo: { classPropertyName: "logo", publicName: "logo", isSignal: true, isRequired: false, transformFunction: null }, nomeUsuario: { classPropertyName: "nomeUsuario", publicName: "nomeUsuario", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onSelectMaster: "onSelectMaster", onFilter: "onFilter" }, ngImport: i0, template: "<div\r\n class=\"bg-white h-auto border-round-lg lg:p-3 p-1 flex flex-column gap-2\"\r\n [style.max-width.rem]=\"'45'\"\r\n [style.min-width]=\"minWidthCard()\"\r\n>\r\n <div class=\"px-2 flex flex-column align-items-center gap-2\">\r\n <img [src]=\"logo()\" style=\"height: 4rem\" class=\" py-2\" />\r\n <span class=\"text-sm\">\r\n Ol\u00E1, <b>{{ nomeUsuario() }}</b\r\n >. Bem vindo (a)! Escolha a <b>Licen\u00E7a</b> que deseja acessar:\r\n </span>\r\n </div>\r\n\r\n @if(masters().length > 6) {\r\n <div\r\n class=\"col-12 grid formgrid p-fluid m-0 px-2 pt-2 pb-0\"\r\n [formGroup]=\"workspaceForm\"\r\n >\r\n <kv-input-text\r\n placeholder=\"Buscar licen\u00E7a\"\r\n class=\"col-12 m-0 p-0\"\r\n (onInput)=\"buscarMasters()\"\r\n formControlName=\"search\"\r\n ></kv-input-text>\r\n </div>\r\n }\r\n\r\n <div\r\n class=\"grid m-0 border-round-lg gap-2 p-2 {{\r\n filteredMasters().length > 6 && 'overflow-y-auto'\r\n }} max-h-24rem cards-container\"\r\n >\r\n @for(master of filteredMasters(); track $index) {\r\n <div\r\n class=\"{{\r\n $index % 2 == 0 ? 'sm:col-6 col-12' : 'sm:col col-12'\r\n }} p-0 card-option\"\r\n (click)=\"selectMaster(master)\"\r\n >\r\n <div class=\"flex flex-column gap-3 p-3\">\r\n <div class=\"flex flex-row align-items-center gap-1 font-semibold\">\r\n <span class=\"material-symbols-outlined text-md\"> verified </span>\r\n <span class=\"text-sm\">{{\r\n isEmpresa()(master.cpfcnpj) ? \"CNPJ:\" : \"CPF:\"\r\n }}</span>\r\n <span class=\"text-sm\">{{ transformCpfCnpj()(master.cpfcnpj) }}</span>\r\n </div>\r\n\r\n <span style=\"word-break: break-word text-medium\" class=\"text-sm\">{{\r\n master.nome\r\n }}</span>\r\n </div>\r\n </div>\r\n } @if(filteredMasters().length == 0) {\r\n <p>{{ emptyText() }}</p>\r\n }\r\n </div>\r\n</div>\r\n", styles: [".card-option{background-color:#fff;border-radius:.5rem;border:1px solid #eaeaea;height:7.5rem;overflow:hidden;transition:all .2s ease-in-out;cursor:pointer}.card-option:hover{border:1px solid #581999;background-color:#d0b3dd4d}.card-option:hover span{color:#581999}.card-option:active{background-color:#d0b3dd99}.cards-container::-webkit-scrollbar{width:6px}.cards-container::-webkit-scrollbar:hover{background-color:#dededebf}.cards-container::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}.cards-container:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}.cards-container::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}span{color:#64748b}\n"], dependencies: [{ kind: "component", type: KvInputTextComponent, selector: "kv-input-text", inputs: ["textCaptalized"] }, { kind: "directive", type: i2$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2$1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] }); }
8800
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvCardSelectionComponent, selector: "kv-card-selection", inputs: { masters: { classPropertyName: "masters", publicName: "masters", isSignal: true, isRequired: false, transformFunction: null }, emptyText: { classPropertyName: "emptyText", publicName: "emptyText", isSignal: true, isRequired: false, transformFunction: null }, logo: { classPropertyName: "logo", publicName: "logo", isSignal: true, isRequired: false, transformFunction: null }, nomeUsuario: { classPropertyName: "nomeUsuario", publicName: "nomeUsuario", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onSelectMaster: "onSelectMaster", onFilter: "onFilter" }, ngImport: i0, template: "<div\r\n class=\"bg-white h-auto border-round-lg lg:p-3 p-1 flex flex-column gap-2\"\r\n [style.max-width.rem]=\"'45'\"\r\n [style.min-width]=\"minWidthCard()\"\r\n>\r\n <div class=\"px-2 flex flex-column align-items-center gap-2\">\r\n <img [src]=\"logo()\" style=\"height: 4rem\" class=\" py-2\" />\r\n <span class=\"text-sm\">\r\n Ol\u00E1, <b>{{ nomeUsuario() }}</b\r\n >. Bem vindo (a)! Escolha a <b>Licen\u00E7a</b> que deseja acessar:\r\n </span>\r\n </div>\r\n\r\n @if(masters().length > 6) {\r\n <div\r\n class=\"col-12 grid formgrid p-fluid m-0 px-2 pt-2 pb-0\"\r\n [formGroup]=\"workspaceForm\"\r\n >\r\n <kv-input-text\r\n placeholder=\"Buscar licen\u00E7a\"\r\n class=\"col-12 m-0 p-0\"\r\n (onInput)=\"buscarMasters()\"\r\n formControlName=\"search\"\r\n ></kv-input-text>\r\n </div>\r\n }\r\n\r\n <div\r\n class=\"grid m-0 border-round-lg gap-2 p-2 {{\r\n (filteredMasters().length > 6 || this.widthScreen() < 992) && 'overflow-y-auto'\r\n }} max-h-24rem cards-container\"\r\n >\r\n @for(master of filteredMasters(); track $index) {\r\n <div\r\n class=\"{{\r\n $index % 2 == 0 ? 'sm:col-6 col-12' : 'sm:col col-12'\r\n }} p-0 card-option\"\r\n (click)=\"selectMaster(master)\"\r\n >\r\n <div class=\"flex flex-column gap-3 p-3\">\r\n <div class=\"flex flex-row align-items-center gap-1 font-semibold\">\r\n <span class=\"material-symbols-outlined text-md\"> verified </span>\r\n <span class=\"text-sm\">{{\r\n isEmpresa()(master.cpfcnpj) ? \"CNPJ:\" : \"CPF:\"\r\n }}</span>\r\n <span class=\"text-sm\">{{ transformCpfCnpj()(master.cpfcnpj) }}</span>\r\n </div>\r\n\r\n <span style=\"word-break: break-word text-medium\" class=\"text-sm\">{{\r\n master.nome\r\n }}</span>\r\n </div>\r\n </div>\r\n } @if(filteredMasters().length == 0) {\r\n <p>{{ emptyText() }}</p>\r\n }\r\n </div>\r\n</div>\r\n", styles: [".card-option{background-color:#fff;border-radius:.5rem;border:1px solid #eaeaea;height:7.5rem;overflow:hidden;transition:all .2s ease-in-out;cursor:pointer}.card-option:hover{border:1px solid #581999;background-color:#d0b3dd4d}.card-option:hover span{color:#581999}.card-option:active{background-color:#d0b3dd99}.cards-container::-webkit-scrollbar{width:6px}.cards-container::-webkit-scrollbar:hover{background-color:#dededebf}.cards-container::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}.cards-container:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}.cards-container::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}span{color:#64748b}\n"], dependencies: [{ kind: "component", type: KvInputTextComponent, selector: "kv-input-text", inputs: ["textCaptalized"] }, { kind: "directive", type: i2$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2$1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] }); }
8806
8801
  }
8807
8802
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvCardSelectionComponent, decorators: [{
8808
8803
  type: Component,
8809
- args: [{ selector: 'kv-card-selection', standalone: false, template: "<div\r\n class=\"bg-white h-auto border-round-lg lg:p-3 p-1 flex flex-column gap-2\"\r\n [style.max-width.rem]=\"'45'\"\r\n [style.min-width]=\"minWidthCard()\"\r\n>\r\n <div class=\"px-2 flex flex-column align-items-center gap-2\">\r\n <img [src]=\"logo()\" style=\"height: 4rem\" class=\" py-2\" />\r\n <span class=\"text-sm\">\r\n Ol\u00E1, <b>{{ nomeUsuario() }}</b\r\n >. Bem vindo (a)! Escolha a <b>Licen\u00E7a</b> que deseja acessar:\r\n </span>\r\n </div>\r\n\r\n @if(masters().length > 6) {\r\n <div\r\n class=\"col-12 grid formgrid p-fluid m-0 px-2 pt-2 pb-0\"\r\n [formGroup]=\"workspaceForm\"\r\n >\r\n <kv-input-text\r\n placeholder=\"Buscar licen\u00E7a\"\r\n class=\"col-12 m-0 p-0\"\r\n (onInput)=\"buscarMasters()\"\r\n formControlName=\"search\"\r\n ></kv-input-text>\r\n </div>\r\n }\r\n\r\n <div\r\n class=\"grid m-0 border-round-lg gap-2 p-2 {{\r\n filteredMasters().length > 6 && 'overflow-y-auto'\r\n }} max-h-24rem cards-container\"\r\n >\r\n @for(master of filteredMasters(); track $index) {\r\n <div\r\n class=\"{{\r\n $index % 2 == 0 ? 'sm:col-6 col-12' : 'sm:col col-12'\r\n }} p-0 card-option\"\r\n (click)=\"selectMaster(master)\"\r\n >\r\n <div class=\"flex flex-column gap-3 p-3\">\r\n <div class=\"flex flex-row align-items-center gap-1 font-semibold\">\r\n <span class=\"material-symbols-outlined text-md\"> verified </span>\r\n <span class=\"text-sm\">{{\r\n isEmpresa()(master.cpfcnpj) ? \"CNPJ:\" : \"CPF:\"\r\n }}</span>\r\n <span class=\"text-sm\">{{ transformCpfCnpj()(master.cpfcnpj) }}</span>\r\n </div>\r\n\r\n <span style=\"word-break: break-word text-medium\" class=\"text-sm\">{{\r\n master.nome\r\n }}</span>\r\n </div>\r\n </div>\r\n } @if(filteredMasters().length == 0) {\r\n <p>{{ emptyText() }}</p>\r\n }\r\n </div>\r\n</div>\r\n", styles: [".card-option{background-color:#fff;border-radius:.5rem;border:1px solid #eaeaea;height:7.5rem;overflow:hidden;transition:all .2s ease-in-out;cursor:pointer}.card-option:hover{border:1px solid #581999;background-color:#d0b3dd4d}.card-option:hover span{color:#581999}.card-option:active{background-color:#d0b3dd99}.cards-container::-webkit-scrollbar{width:6px}.cards-container::-webkit-scrollbar:hover{background-color:#dededebf}.cards-container::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}.cards-container:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}.cards-container::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}span{color:#64748b}\n"] }]
8804
+ args: [{ selector: 'kv-card-selection', standalone: false, template: "<div\r\n class=\"bg-white h-auto border-round-lg lg:p-3 p-1 flex flex-column gap-2\"\r\n [style.max-width.rem]=\"'45'\"\r\n [style.min-width]=\"minWidthCard()\"\r\n>\r\n <div class=\"px-2 flex flex-column align-items-center gap-2\">\r\n <img [src]=\"logo()\" style=\"height: 4rem\" class=\" py-2\" />\r\n <span class=\"text-sm\">\r\n Ol\u00E1, <b>{{ nomeUsuario() }}</b\r\n >. Bem vindo (a)! Escolha a <b>Licen\u00E7a</b> que deseja acessar:\r\n </span>\r\n </div>\r\n\r\n @if(masters().length > 6) {\r\n <div\r\n class=\"col-12 grid formgrid p-fluid m-0 px-2 pt-2 pb-0\"\r\n [formGroup]=\"workspaceForm\"\r\n >\r\n <kv-input-text\r\n placeholder=\"Buscar licen\u00E7a\"\r\n class=\"col-12 m-0 p-0\"\r\n (onInput)=\"buscarMasters()\"\r\n formControlName=\"search\"\r\n ></kv-input-text>\r\n </div>\r\n }\r\n\r\n <div\r\n class=\"grid m-0 border-round-lg gap-2 p-2 {{\r\n (filteredMasters().length > 6 || this.widthScreen() < 992) && 'overflow-y-auto'\r\n }} max-h-24rem cards-container\"\r\n >\r\n @for(master of filteredMasters(); track $index) {\r\n <div\r\n class=\"{{\r\n $index % 2 == 0 ? 'sm:col-6 col-12' : 'sm:col col-12'\r\n }} p-0 card-option\"\r\n (click)=\"selectMaster(master)\"\r\n >\r\n <div class=\"flex flex-column gap-3 p-3\">\r\n <div class=\"flex flex-row align-items-center gap-1 font-semibold\">\r\n <span class=\"material-symbols-outlined text-md\"> verified </span>\r\n <span class=\"text-sm\">{{\r\n isEmpresa()(master.cpfcnpj) ? \"CNPJ:\" : \"CPF:\"\r\n }}</span>\r\n <span class=\"text-sm\">{{ transformCpfCnpj()(master.cpfcnpj) }}</span>\r\n </div>\r\n\r\n <span style=\"word-break: break-word text-medium\" class=\"text-sm\">{{\r\n master.nome\r\n }}</span>\r\n </div>\r\n </div>\r\n } @if(filteredMasters().length == 0) {\r\n <p>{{ emptyText() }}</p>\r\n }\r\n </div>\r\n</div>\r\n", styles: [".card-option{background-color:#fff;border-radius:.5rem;border:1px solid #eaeaea;height:7.5rem;overflow:hidden;transition:all .2s ease-in-out;cursor:pointer}.card-option:hover{border:1px solid #581999;background-color:#d0b3dd4d}.card-option:hover span{color:#581999}.card-option:active{background-color:#d0b3dd99}.cards-container::-webkit-scrollbar{width:6px}.cards-container::-webkit-scrollbar:hover{background-color:#dededebf}.cards-container::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}.cards-container:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}.cards-container::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}span{color:#64748b}\n"] }]
8810
8805
  }] });
8811
8806
 
8812
8807
  class KvCardSelectionModule {