keevo-components 1.8.457 → 1.8.459

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,21 +1,16 @@
1
- import { Component, computed, HostListener, Injectable, signal, ViewChild } from '@angular/core';
1
+ import { Component, Injectable, signal } from '@angular/core';
2
2
  import { DialogModule } from 'primeng/dialog';
3
+ import { ImageCropperComponent } from 'ngx-image-cropper';
3
4
  // ? Componente de modal usado no cutter
4
- import { SliderModule } from 'primeng/slider';
5
5
  import { CommonModule } from '@angular/common';
6
6
  import { FormsModule, ReactiveFormsModule } from '@angular/forms';
7
- import { ButtonModule } from 'primeng/button';
8
- import { FileUploadModule } from 'primeng/fileupload';
9
7
  import { KvLabelModule } from '../../components/kv-label/kv-label.module';
10
8
  import { FormService } from './form.service';
11
9
  import { KvModalModule } from '../../components/kv-modal/kv-modal.module';
12
10
  import { KvButtonModule } from '../../components/kv-button/kv-button.module';
13
11
  import * as i0 from "@angular/core";
14
12
  import * as i1 from "primeng/dynamicdialog";
15
- import * as i2 from "primeng/slider";
16
- import * as i3 from "@angular/forms";
17
- import * as i4 from "../../components/kv-button/kv-button.component";
18
- import * as i5 from "../../components/kv-label/kv-label.component";
13
+ import * as i2 from "../../components/kv-button/kv-button.component";
19
14
  export class ImageCutterService {
20
15
  constructor(dialogservice) {
21
16
  this.dialogservice = dialogservice;
@@ -51,158 +46,39 @@ export class ImageCutterService {
51
46
  }
52
47
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ImageCutterService, decorators: [{
53
48
  type: Injectable,
54
- args: [{
55
- providedIn: 'root'
56
- }]
49
+ args: [{ providedIn: 'root' }]
57
50
  }], ctorParameters: () => [{ type: i1.DialogService }] });
58
51
  class SimpleComponent {
59
52
  constructor(dynamicDialogRef, dialogService) {
60
53
  this.dynamicDialogRef = dynamicDialogRef;
61
54
  this.dialogService = dialogService;
62
- // ? Variavies que recebem os valores do dialog
55
+ this.imageChangedEvent = null;
56
+ this.croppedImage = '';
57
+ //#region Variáveis de controle
63
58
  this._variaviesDialog = signal(null);
64
- //? Referências para o contexto e canvas
65
- this.canvas = signal(null);
66
- this.ctx = signal(null);
67
- this._Image = signal(new Image());
68
- //? Coordenadas iniciais e finais do desenho
69
- this.startX = 0;
70
- this.startY = 0;
71
- //? Fator de escala da imagem e zoom
72
- this.scaleFactorReadOnly = computed(() => {
73
- return Math.min(this.scaleFactor(), this.scaleFactorInicial() + 5);
74
- });
75
- this.scaleFactorInicial = signal(null);
76
- this.scaleFactor = signal(null);
77
- this.scaleFactorModel = 0;
78
- this.imageX = 0;
79
- this.imageY = 0;
80
- //#region Propriedades computadas de tamanho do canvas e da imagem
81
- //? Largura e altura do canvas baseado na tamanho da tela
82
- this.canvasWidth = computed(() => this.widthTela() * 0.5);
83
- this.canvasHeight = computed(() => this.heigthTela() * 0.5);
84
- //? Largura e altura da área de corte
85
- this.cutWidth = computed(() => {
86
- if (this._variaviesDialog()?.indCircle) {
87
- return this.radius() * 2;
88
- }
89
- else {
90
- const canvasWidth = this.canvasWidth();
91
- const maxWidth = canvasWidth * 0.8;
92
- const proportionalHeight = maxWidth * this.proporcaoImagem();
93
- return proportionalHeight > this.canvasHeight() * 0.8 ? this.canvasHeight() * 0.8 / this.proporcaoImagem() : maxWidth;
94
- }
95
- });
96
- this.cutHeight = computed(() => {
97
- if (this._variaviesDialog()?.indCircle) {
98
- return this.radius() * 2;
99
- }
100
- else {
101
- const canvasHeight = this.canvasHeight();
102
- const maxHeight = canvasHeight * 0.8;
103
- const proportionalWidth = maxHeight / this.proporcaoImagem();
104
- return proportionalWidth > this.canvasWidth() * 0.8 ? this.canvasWidth() * 0.8 * this.proporcaoImagem() : maxHeight;
105
- }
106
- });
107
- //? Largura e altura da imagem no canvas (baseado na escala) - tamanho real da imagem
108
- this.canvaImageWidth = computed(() => {
109
- return this._Image().width * this.scaleFactorReadOnly();
110
- });
111
- this.canvaImageHeight = computed(() => {
112
- return this._Image().height * this.scaleFactorReadOnly();
113
- });
114
- this.proporcaoImagem = computed(() => {
115
- return this._variaviesDialog()?.height / this._variaviesDialog()?.width;
116
- });
117
- this.radius = computed(() => {
118
- const minSize = Math.min(this.canvasHeight() * 0.8, this.canvasWidth() * 0.8);
119
- return minSize / 2;
120
- });
121
- //#endregion
122
- // #region Limites de movimentação da imagem
123
- //? Limites de movimentação da imagem
124
- this.indCircle = computed(() => {
125
- return this._variaviesDialog()?.indCircle;
126
- });
127
- this.xMin = computed(() => {
128
- return !this._variaviesDialog()?.indCircle ? (this.canvasWidth() - this.cutWidth()) / 2 : (this.canvasWidth() - (this.radius() * 2)) / 2;
129
- });
130
- this.yMin = computed(() => {
131
- return !this._variaviesDialog()?.indCircle ? (this.canvasHeight() - this.cutHeight()) / 2 : (this.canvasHeight() - (this.radius() * 2)) / 2;
132
- });
133
- this.xMax = computed(() => {
134
- return !this._variaviesDialog()?.indCircle ? -(this.canvaImageWidth() - (this.xMin()) - this.cutWidth()) : -(this.canvaImageWidth() - (this.xMin()) - (this.radius() * 2));
135
- });
136
- this.yMax = computed(() => {
137
- return !this._variaviesDialog()?.indCircle ? -(this.canvaImageHeight() - (this.yMin()) - this.cutHeight()) : -(this.canvaImageHeight() - (this.yMin()) - (this.radius() * 2));
138
- });
139
- // #endregion
140
- //? Proporção da imagem
141
- this.widthTela = signal(0);
142
- this.heigthTela = signal(0);
143
- //#endregion
144
- //#region handlers de eventos
145
- this.comparadorOnZoomChange = this.scaleFactorInicial();
146
- this.atualizaTamanhoTela();
59
+ this.aspectRatio = signal(1 / 1);
147
60
  }
148
- setScaleFactorModel(valor) {
149
- this.scaleFactorModel = valor - this.scaleFactorInicial();
150
- this.scaleFactor.set(valor);
61
+ fileChangeEvent(event) {
62
+ this.imageChangedEvent = event;
151
63
  }
152
- onWindowResize() {
153
- this.atualizaTamanhoTela();
154
- this.updateCanvasSize();
155
- this.atualizaCutBorder();
64
+ imageCropped(event) {
65
+ this.croppedImage = event.base64;
156
66
  }
157
- atualizaTamanhoTela() {
158
- this.widthTela.set(window.innerWidth);
159
- this.heigthTela.set(window.innerHeight);
160
- }
161
- ngAfterViewInit() {
67
+ imageLoaded(image) { }
68
+ cropperReady() { }
69
+ loadImageFailed() { }
70
+ //#endregion
71
+ ngAfterContentInit() {
162
72
  this.recuperarVariaviesDialog();
163
- this.inciarReferencias();
164
- this.iniciarCanvas();
73
+ this.recuperaInstanciaDialog();
74
+ this.setAspectRatio();
165
75
  }
166
- inciarReferencias() {
167
- this.canvas.set(this.cropCanvas.nativeElement);
168
- this.ctx.set(this.canvas().getContext('2d'));
169
- this._Image().src = this._variaviesDialog()?.imagem;
170
- }
171
- iniciarCanvas() {
172
- this._Image().onload = () => {
173
- //? Define o tamanho do canvas
174
- this.canvas().height = this.canvasHeight();
175
- this.canvas().width = this.canvasWidth();
176
- this.ajustarZommEPosicaoInicial();
177
- this.initializeImageMove(this.canvas(), this.ctx(), this._Image());
178
- this.initializeMouseWheel(this.canvas(), this.ctx(), this._Image());
179
- this.redrawCanvas(this.ctx(), this._Image());
180
- };
181
- }
182
- ajustarZommEPosicaoInicial() {
183
- const cutWidth = this.cutWidth();
184
- const cutHeight = this.cutHeight();
185
- const imageWidth = this._Image().width;
186
- const imageHeight = this._Image().height;
187
- //? Ajusta possição e zoom inicial
188
- if (this._variaviesDialog()?.indCircle) {
189
- const scaleFactor = (this.radius() * 2) / Math.min(imageWidth, imageHeight);
190
- this.scaleFactorInicial.set(scaleFactor);
191
- this.setScaleFactorModel(scaleFactor);
192
- }
193
- else {
194
- const scaleFactor = this.cutHeight() === this.cutWidth()
195
- ? this._Image().width > this._Image().height
196
- ? this.cutHeight() / imageHeight
197
- : this.cutWidth() / imageWidth
198
- : this.cutHeight() > this.cutWidth()
199
- ? this.cutHeight() / imageHeight
200
- : this.cutWidth() / imageWidth;
201
- this.scaleFactorInicial.set(scaleFactor);
202
- this.setScaleFactorModel(scaleFactor);
203
- }
204
- this.imageX = Math.max((this.canvas().width - imageWidth * this.scaleFactorReadOnly()) / 2, this.xMin());
205
- this.imageY = Math.max((this.canvasHeight() - imageHeight * this.scaleFactorReadOnly()) / 2, this.yMin());
76
+ setAspectRatio(width = this._variaviesDialog()?.width, height = this._variaviesDialog()?.height) {
77
+ const gcd = (a, b) => (b === 0 ? a : gcd(b, a % b));
78
+ const divisor = gcd(width, height);
79
+ const aspectWidth = width / divisor;
80
+ const aspectHeight = height / divisor;
81
+ this.aspectRatio.set(aspectWidth / aspectHeight);
206
82
  }
207
83
  //#region Métodos de recuperação de dados
208
84
  recuperaInstanciaDialog() {
@@ -218,273 +94,13 @@ class SimpleComponent {
218
94
  this._variaviesDialog.set(this.recuperaInstanciaDialog().data.id);
219
95
  }
220
96
  //#endregion
221
- //#region Métodos de atualizacao do canvas
222
- //? Atualiza o tamanho do canvas
223
- updateCanvasSize() {
224
- this.imageX = (this.canvas().width - this._Image().width * this.scaleFactorReadOnly()) / 2;
225
- this.imageY = (this.canvasHeight() / 2) - (this._Image().height * this.scaleFactorReadOnly()) / 2;
226
- this.canvas().height = this.canvasHeight();
227
- this.canvas().width = this.canvasWidth();
228
- this.redrawCanvas(this.ctx(), this._Image());
229
- }
230
- redrawCanvas(ctx, img) {
231
- if (!ctx)
232
- return;
233
- this.drawCropArea(ctx);
234
- ctx.clearRect(0, 0, ctx.canvas.width, ctx.canvas.height);
235
- ctx.filter = 'blur(5px) opacity(0.9)';
236
- ctx.drawImage(img, this.imageX, this.imageY, img.width * this.scaleFactorReadOnly(), img.height * this.scaleFactorReadOnly());
237
- ctx.filter = 'none';
238
- this.drawImageInCropArea(ctx, img);
239
- }
240
- //? Desenha a área de corte
241
- drawCropArea(ctx) {
242
- if (!ctx)
243
- return;
244
- this.atualizaCutBorder();
245
- const cropX = ctx.canvas.width / 2 - this.cutWidth() / 2;
246
- const cropY = ctx.canvas.height / 2 - this.cutHeight() / 2;
247
- const cropXCircle = ctx.canvas.width / 2 - this.radius() / 2;
248
- const cropYCircle = ctx.canvas.height / 2 - this.radius() / 2;
249
- ctx.beginPath();
250
- ctx.strokeStyle = 'transparent';
251
- ctx.lineWidth = 2;
252
- if (this._variaviesDialog()?.indCircle) {
253
- ctx.arc(cropXCircle, cropYCircle, this.radius(), 0, Math.PI * 2, true);
254
- }
255
- else {
256
- ctx.rect(cropX, cropY, this.cutWidth(), this.cutHeight());
257
- }
258
- ctx.stroke();
259
- }
260
- //? Desenha a imagem na área de corte
261
- drawImageInCropArea(ctx, img) {
262
- if (!ctx)
263
- return;
264
- const cropX = (ctx.canvas.width - this.cutWidth()) / 2;
265
- const cropY = (ctx.canvas.height - this.cutHeight()) / 2;
266
- ctx.save();
267
- ctx.beginPath();
268
- if (this._variaviesDialog()?.indCircle) {
269
- ctx.arc(ctx.canvas.width / 2, ctx.canvas.height / 2, this.radius(), 0, Math.PI * 2, true);
270
- }
271
- else {
272
- ctx.rect(cropX, cropY, this.cutWidth(), this.cutHeight());
273
- }
274
- ctx.clip();
275
- ctx.drawImage(img, this.imageX, this.imageY, img.width * this.scaleFactorReadOnly(), img.height * this.scaleFactorReadOnly());
276
- ctx.restore();
277
- }
278
- atualizaCutBorder() {
279
- if (this.cropBorder && this.cropBorder.nativeElement) {
280
- const cropBorderElement = this.cropBorder.nativeElement;
281
- if (this._variaviesDialog()?.indCircle) {
282
- cropBorderElement.style.borderRadius = this.radius() * 2 + 'px';
283
- cropBorderElement.style.width = this.radius() * 2 + 'px';
284
- cropBorderElement.style.height = this.radius() * 2 + 'px';
285
- }
286
- else {
287
- cropBorderElement.style.width = this.cutWidth() + 'px';
288
- cropBorderElement.style.height = this.cutHeight() + 'px';
289
- }
290
- }
291
- }
292
- onZoomChange(e) {
293
- const prevZoom = this.comparadorOnZoomChange;
294
- const zoomValue = e.value;
295
- this.comparadorOnZoomChange = e.value;
296
- const direction = prevZoom < zoomValue ? 'up' : 'down';
297
- this.ajustarZoom(direction, e.value);
298
- }
299
- initializeMouseWheel(canvas, ctx, img) {
300
- canvas.onwheel = (e) => {
301
- e.preventDefault();
302
- //? Recuperando os valores de zoom e delta atuais
303
- const direction = e.deltaY > 0 ? 'down' : 'up';
304
- this.ajustarZoom(direction);
305
- };
306
- }
307
- ajustarZoom(direction, value) {
308
- const prevScaleFactor = this.scaleFactorReadOnly();
309
- const delta = direction == 'down' ? -0.015 : 0.015;
310
- let scaleFactor = prevScaleFactor + (delta * 1.4);
311
- if (value)
312
- scaleFactor = value + this.scaleFactorInicial();
313
- const newHeight = this._Image().height * scaleFactor;
314
- const newWidth = this._Image().width * scaleFactor;
315
- if (this._variaviesDialog()?.indCircle) {
316
- if (newHeight < this.radius() * 2 || newWidth < this.radius() * 2) {
317
- scaleFactor = prevScaleFactor;
318
- }
319
- else {
320
- this.scaleFactor.set(scaleFactor);
321
- this.setScaleFactorModel(scaleFactor);
322
- }
323
- }
324
- else {
325
- if (newHeight < this.cutHeight() || newWidth < this.cutWidth()) {
326
- scaleFactor = prevScaleFactor;
327
- }
328
- else {
329
- this.scaleFactor.set(scaleFactor);
330
- this.setScaleFactorModel(scaleFactor);
331
- }
332
- }
333
- this.scaleFactor.set(scaleFactor);
334
- this.setScaleFactorModel(scaleFactor);
335
- const canvas = this.cropCanvas.nativeElement;
336
- const canvasWidth = canvas.offsetWidth;
337
- const canvasHeight = canvas.offsetHeight;
338
- const centerX = canvasWidth / 2;
339
- const centerY = canvasHeight / 2;
340
- const newCanvasX = centerX - (centerX - this.imageX) * (scaleFactor / prevScaleFactor);
341
- const newCanvasY = centerY - (centerY - this.imageY) * (scaleFactor / prevScaleFactor);
342
- this.imageX = newCanvasX;
343
- this.imageY = newCanvasY;
344
- if (!this.verificaImagemdentroDosLimiteXmin()) {
345
- const diffXmin = this.retornaDiffXmax();
346
- this.moveImage(this.imageX - diffXmin);
347
- }
348
- if (!this.verificaImagemdentroDosLimiteXmax()) {
349
- const diffXmax = this.retornaDiffXmin();
350
- this.moveImage(this.imageX + diffXmax);
351
- }
352
- if (!this.verificaImagemdentroDosLimiteYmax()) {
353
- const diffYmax = this.retornaDiffYmin();
354
- this.moveImage(undefined, this.imageY + diffYmax);
355
- }
356
- if (!this.verificaImagemdentroDosLimiteYmin()) {
357
- const diffYmin = this.retornaDiffYmax();
358
- this.moveImage(undefined, this.imageY - diffYmin);
359
- }
360
- this.redrawCanvas(this.ctx(), this._Image());
361
- }
362
- verificaImagemdentroDosLimiteXmin() {
363
- const newImageX = this.imageX;
364
- return newImageX < this.xMin();
365
- }
366
- verificaImagemdentroDosLimiteXmax() {
367
- const newImageX = this.imageX;
368
- return newImageX > this.xMax();
369
- }
370
- verificaImagemdentroDosLimiteYmin() {
371
- const newImageY = this.imageY;
372
- return newImageY < this.yMin();
373
- }
374
- verificaImagemdentroDosLimiteYmax() {
375
- const newImageY = this.imageY;
376
- return newImageY > this.yMax();
377
- }
378
- retornaDiffXmin() {
379
- const newImageX = this.imageX;
380
- return this.xMin() - newImageX;
381
- }
382
- retornaDiffXmax() {
383
- const newImageX = this.imageX;
384
- return newImageX - this.xMax();
385
- }
386
- retornaDiffYmin() {
387
- const newImageY = this.imageY;
388
- return this.yMin() - newImageY;
389
- }
390
- retornaDiffYmax() {
391
- const newImageY = this.imageY;
392
- return newImageY - this.yMax();
393
- }
394
- initializeImageMove(canvas, ctx, img) {
395
- let isDragging = false;
396
- canvas.style.cursor = 'grab';
397
- canvas.onmousedown = (e) => {
398
- isDragging = true;
399
- canvas.style.cursor = 'grabbing';
400
- this.startX = e.offsetX - this.imageX;
401
- this.startY = e.offsetY - this.imageY;
402
- };
403
- canvas.onmouseup = () => {
404
- isDragging = false;
405
- canvas.style.cursor = 'grab';
406
- };
407
- canvas.onmouseout = () => {
408
- isDragging = false;
409
- canvas.style.cursor = 'grab';
410
- };
411
- canvas.onmousemove = (e) => {
412
- if (isDragging) {
413
- // Calcula o novo posicionamento da imagem
414
- let newImageX = e.offsetX - this.startX;
415
- let newImageY = e.offsetY - this.startY;
416
- if (newImageX < this.xMin() && newImageX > this.xMax()) {
417
- this.moveImage(newImageX);
418
- }
419
- if (newImageY < this.yMin() && newImageY > this.yMax()) {
420
- this.moveImage(undefined, newImageY);
421
- }
422
- this.redrawCanvas(ctx, img);
423
- }
424
- };
425
- }
426
- moveImage(dx, dy) {
427
- this.imageX = (dx ?? this.imageX);
428
- this.imageY = (dy ?? this.imageY);
429
- }
430
- //#endregion
431
97
  //#region Métodos de corte e fechamento do modal
432
98
  cropImage() {
433
- const ctx = this.ctx();
434
- if (ctx) {
435
- const X = ((this.canvas().width - this._Image().width * this.scaleFactorReadOnly()) / 2);
436
- const Y = ((this.canvasHeight() / 2) - (this._Image().height * this.scaleFactorReadOnly()) / 2);
437
- // Recuperar o imageData da imagem que está na área de corte
438
- let imageData;
439
- const cropX = (ctx.canvas.width - this.cutWidth()) / 2;
440
- const cropY = (ctx.canvas.height - this.cutHeight()) / 2;
441
- if (this._variaviesDialog()?.indCircle) {
442
- // Create a new canvas with the same dimensions as the circle
443
- const circleCanvas = document.createElement('canvas');
444
- const circleCtx = circleCanvas.getContext('2d');
445
- circleCanvas.width = this.radius() * 2;
446
- circleCanvas.height = this.radius() * 2;
447
- // Draw the circle on the new canvas
448
- circleCtx.beginPath();
449
- circleCtx.arc(this.radius(), this.radius(), this.radius(), 0, 2 * Math.PI);
450
- circleCtx.fill();
451
- // Set the composite operation to 'destination-in' to cut out the circle
452
- ctx.globalCompositeOperation = 'destination-in';
453
- // Draw the image on the main canvas using the circle as a mask
454
- ctx.drawImage(circleCanvas, cropX, cropY);
455
- // Reset the composite operation to the default value
456
- ctx.globalCompositeOperation = 'source-over';
457
- // Get the image data of the cropped circle
458
- imageData = ctx.getImageData(cropX, cropY, this.radius() * 2, this.radius() * 2);
459
- }
460
- else {
461
- imageData = ctx.getImageData(cropX, cropY, this.cutWidth(), this.cutHeight());
462
- }
463
- // Obter os valores de width e height da variável _variaviesDialog
464
- const variaveisDialog = this._variaviesDialog();
465
- if (variaveisDialog) {
466
- const { width, height } = variaveisDialog;
467
- // Criar um novo canvas e contexto com os valores de width e height
468
- const newCanvas = document.createElement('canvas');
469
- const newCtx = newCanvas.getContext('2d');
470
- newCanvas.width = width;
471
- newCanvas.height = height;
472
- if (newCtx) {
473
- // Redimensionar a imagem para o tamanho especificado
474
- const tempCanvas = document.createElement('canvas');
475
- const tempCtx = tempCanvas.getContext('2d');
476
- tempCanvas.width = this.cutWidth();
477
- tempCanvas.height = this.cutHeight();
478
- tempCtx.putImageData(imageData, 0, 0);
479
- newCtx.drawImage(tempCanvas, 0, 0, width, height);
480
- window.dispatchEvent(new CustomEvent('cropImage', { detail: {
481
- result: Promise.resolve(newCanvas.toDataURL()),
482
- status: true
483
- } }));
484
- this.closeCropModal();
485
- }
486
- }
487
- }
99
+ window.dispatchEvent(new CustomEvent('cropImage', { detail: {
100
+ result: this.croppedImage,
101
+ status: true
102
+ } }));
103
+ this.closeCropModal();
488
104
  }
489
105
  closeCropModal() {
490
106
  this.dialogInstance.close();
@@ -497,73 +113,73 @@ class SimpleComponent {
497
113
  this.closeCropModal();
498
114
  }
499
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 }); }
500
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: SimpleComponent, isStandalone: true, selector: "app-simple-component", host: { listeners: { "window:resize": "onWindowResize($event)" } }, viewQueries: [{ propertyName: "cropCanvas", first: true, predicate: ["cropCanvas"], descendants: true }, { propertyName: "cropBorder", first: true, predicate: ["cropBorder"], descendants: true }], ngImport: i0, template: `
116
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: SimpleComponent, isStandalone: true, selector: "app-simple-component", ngImport: i0, template: `
501
117
  <div class="modal-content">
502
- <div class="crop-container">
503
- <canvas #cropCanvas class="crop-canvas"></canvas>
504
- <div #cropBorder class="crop-border"></div>
505
- </div>
506
118
 
507
- <div class="w-full mt-2">
508
- <kv-label label="Zoom" style="text-align: left;" />
509
- <p-slider [(ngModel)]="this.scaleFactorModel" [step]="0.0001" [max]="5" (onChange)="onZoomChange($event)"></p-slider>
510
- </div>
119
+ <image-cropper
120
+ [imageBase64]="_variaviesDialog()?.imagem"
121
+ (imageCropped)="imageCropped($event)"
122
+ [aspectRatio]="aspectRatio()"
123
+ (imageLoaded)="imageLoaded($event)"
124
+ (cropperReady)="cropperReady()"
125
+ (loadImageFailed)="loadImageFailed()"
126
+ [roundCropper]="this._variaviesDialog()?.indCircle"
127
+ [maintainAspectRatio]="true"
128
+ [imageQuality]="100"
129
+ format="jpeg"
130
+ output='base64'
131
+ alignImage="center"
132
+ />
511
133
 
512
- <div class="button-container">
134
+
135
+ </div>
136
+ <div class="button-container">
513
137
  <kv-button label="Cancelar" severity="tertiary" icon="close" (click)="cancel()"></kv-button>
514
138
  <kv-button label="Recortar" severity="primary" icon="crop" (click)="cropImage()" class="ml-2"></kv-button>
515
139
  </div>
516
140
 
517
- </div>
518
141
 
519
142
 
520
-
521
- `, isInline: true, 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{position:relative;background-color:#fefefe;margin:1% auto;padding:20px;width:80%;max-width:fit-content;text-align:center;border-radius:12px}.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}\n"], dependencies: [{ kind: "ngmodule", type: DialogModule }, { kind: "ngmodule", type: KvModalModule }, { kind: "ngmodule", type: SliderModule }, { kind: "component", type: i2.Slider, selector: "p-slider", inputs: ["animate", "disabled", "min", "max", "orientation", "step", "range", "style", "styleClass", "ariaLabel", "ariaLabelledBy", "tabindex", "autofocus"], outputs: ["onChange", "onSlideEnd"] }, { kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: ButtonModule }, { kind: "ngmodule", type: FileUploadModule }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: KvButtonModule }, { kind: "component", type: i4.KvButtonComponent, selector: "kv-button", inputs: ["fullWidth", "type", "loading", "severity", "size", "icon", "label", "disabled"], outputs: ["onClick"] }, { kind: "ngmodule", type: KvLabelModule }, { kind: "component", type: i5.KvLabelComponent, selector: "kv-label", inputs: ["componentId", "label"] }] }); }
143
+ `, isInline: true, 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"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: DialogModule }, { kind: "ngmodule", type: KvModalModule }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: KvButtonModule }, { kind: "component", type: i2.KvButtonComponent, selector: "kv-button", inputs: ["fullWidth", "type", "loading", "severity", "size", "icon", "label", "disabled"], outputs: ["onClick"] }, { kind: "ngmodule", type: KvLabelModule }, { kind: "component", type: ImageCropperComponent, selector: "image-cropper", inputs: ["imageChangedEvent", "imageURL", "imageBase64", "imageFile", "imageAltText", "options", "cropperFrameAriaLabel", "output", "format", "autoCrop", "cropper", "transform", "maintainAspectRatio", "aspectRatio", "resetCropOnAspectRatioChange", "resizeToWidth", "resizeToHeight", "cropperMinWidth", "cropperMinHeight", "cropperMaxHeight", "cropperMaxWidth", "cropperStaticWidth", "cropperStaticHeight", "canvasRotation", "initialStepSize", "roundCropper", "onlyScaleDown", "imageQuality", "backgroundColor", "containWithinAspectRatio", "hideResizeSquares", "allowMoveImage", "checkImageType", "alignImage", "disabled", "hidden"], outputs: ["imageCropped", "startCropImage", "imageLoaded", "cropperReady", "loadImageFailed", "transformChange", "cropperChange"] }] }); }
522
144
  }
523
145
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: SimpleComponent, decorators: [{
524
146
  type: Component,
525
147
  args: [{ selector: 'app-simple-component', template: `
526
148
  <div class="modal-content">
527
- <div class="crop-container">
528
- <canvas #cropCanvas class="crop-canvas"></canvas>
529
- <div #cropBorder class="crop-border"></div>
530
- </div>
531
149
 
532
- <div class="w-full mt-2">
533
- <kv-label label="Zoom" style="text-align: left;" />
534
- <p-slider [(ngModel)]="this.scaleFactorModel" [step]="0.0001" [max]="5" (onChange)="onZoomChange($event)"></p-slider>
535
- </div>
150
+ <image-cropper
151
+ [imageBase64]="_variaviesDialog()?.imagem"
152
+ (imageCropped)="imageCropped($event)"
153
+ [aspectRatio]="aspectRatio()"
154
+ (imageLoaded)="imageLoaded($event)"
155
+ (cropperReady)="cropperReady()"
156
+ (loadImageFailed)="loadImageFailed()"
157
+ [roundCropper]="this._variaviesDialog()?.indCircle"
158
+ [maintainAspectRatio]="true"
159
+ [imageQuality]="100"
160
+ format="jpeg"
161
+ output='base64'
162
+ alignImage="center"
163
+ />
536
164
 
537
- <div class="button-container">
165
+
166
+ </div>
167
+ <div class="button-container">
538
168
  <kv-button label="Cancelar" severity="tertiary" icon="close" (click)="cancel()"></kv-button>
539
169
  <kv-button label="Recortar" severity="primary" icon="crop" (click)="cropImage()" class="ml-2"></kv-button>
540
170
  </div>
541
171
 
542
- </div>
543
-
544
172
 
545
173
 
546
174
  `, standalone: true, imports: [
175
+ CommonModule,
547
176
  DialogModule,
548
177
  KvModalModule,
549
- SliderModule,
550
- CommonModule,
551
- ButtonModule,
552
- FileUploadModule,
553
- SliderModule,
554
178
  FormsModule,
555
179
  ReactiveFormsModule,
556
180
  KvButtonModule,
557
181
  KvLabelModule,
558
- ], 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{position:relative;background-color:#fefefe;margin:1% auto;padding:20px;width:80%;max-width:fit-content;text-align:center;border-radius:12px}.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}\n"] }]
559
- }], ctorParameters: () => [{ type: i1.DynamicDialogRef }, { type: i1.DialogService }], propDecorators: { cropCanvas: [{
560
- type: ViewChild,
561
- args: ['cropCanvas']
562
- }], cropBorder: [{
563
- type: ViewChild,
564
- args: ['cropBorder']
565
- }], onWindowResize: [{
566
- type: HostListener,
567
- args: ['window:resize', ['$event']]
568
- }] } });
569
- //# 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, computed, ElementRef, HostListener, Injectable, signal, ViewChild } from '@angular/core';\r\nimport { DialogService, DynamicDialogComponent, DynamicDialogRef } from 'primeng/dynamicdialog';\r\nimport { DialogModule } from 'primeng/dialog';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class ImageCutterService {\r\n\r\n  constructor(\r\n    private readonly dialogservice: DialogService\r\n  ) { }\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\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// ? Componente de modal usado no cutter\r\nimport { SliderModule } from 'primeng/slider';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { FileUploadModule } from 'primeng/fileupload';\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\n\r\n@Component({\r\n  selector: 'app-simple-component',\r\n  template: `\r\n      <div class=\"modal-content\">\r\n        <div class=\"crop-container\">\r\n          <canvas #cropCanvas class=\"crop-canvas\"></canvas>\r\n          <div #cropBorder class=\"crop-border\"></div>\r\n        </div>\r\n\r\n        <div class=\"w-full mt-2\">\r\n          <kv-label label=\"Zoom\" style=\"text-align: left;\" />\r\n          <p-slider [(ngModel)]=\"this.scaleFactorModel\" [step]=\"0.0001\"  [max]=\"5\"  (onChange)=\"onZoomChange($event)\"></p-slider>\r\n        </div>\r\n\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      </div>\r\n\r\n\r\n\r\n  `,\r\n  styles: [`\r\n\r\nimg {\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\ni {\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  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}\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}\r\n\r\n\r\n\r\n  `],\r\n  standalone: true,\r\n  imports: [\r\n    DialogModule,\r\n    KvModalModule,\r\n    SliderModule,\r\n    CommonModule,\r\n    ButtonModule,\r\n    FileUploadModule,\r\n    SliderModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    KvButtonModule,\r\n    KvLabelModule,\r\n\r\n  ]\r\n})\r\n\r\nclass SimpleComponent {\r\n\r\n  constructor(private dynamicDialogRef: DynamicDialogRef, private readonly dialogService: DialogService) {\r\n    this.atualizaTamanhoTela()\r\n  }\r\n\r\n\r\n  // ? Variavies que recebem os valores do dialog\r\n  _variaviesDialog = signal<{ imagem: string, width: number, height: number, indCircle: boolean }|null>(null)\r\n\r\n\r\n\r\n    //? Referência para o elemento que contém a imagem e canvas\r\n    @ViewChild('cropCanvas') cropCanvas!: ElementRef<HTMLCanvasElement>;\r\n    @ViewChild('cropBorder') cropBorder!: ElementRef;\r\n\r\n    //? Referências para o contexto e canvas\r\n    private canvas = signal<HTMLCanvasElement|null>(null);\r\n    private ctx =  signal<CanvasRenderingContext2D|null>(null);\r\n    private _Image = signal<HTMLImageElement>(new Image());\r\n\r\n    //? Coordenadas iniciais e finais do desenho\r\n    private startX = 0;\r\n    private startY = 0;\r\n\r\n    //? Referência para o modal\r\n    private dialogInstance!:DynamicDialogComponent;\r\n\r\n    //? Fator de escala da imagem e zoom\r\n    scaleFactorReadOnly = computed<number>(()=> {\r\n      return Math.min(this.scaleFactor()!, this.scaleFactorInicial()!+5);\r\n    })\r\n\r\n    public scaleFactorInicial = signal<number|null>(null);\r\n\r\n    private scaleFactor = signal<number|null>(null);\r\n\r\n    setScaleFactorModel(valor:number){\r\n      this.scaleFactorModel = valor - this.scaleFactorInicial()!;\r\n      this.scaleFactor.set(valor)\r\n    }\r\n    scaleFactorModel = 0;\r\n\r\n    private imageX: number = 0;\r\n    private imageY: number = 0;\r\n\r\n\r\n    //#region Propriedades computadas de tamanho do canvas e da imagem\r\n      //? Largura e altura do canvas baseado na tamanho da tela\r\n      canvasWidth = computed<number | null>(() => this.widthTela()*0.5);\r\n      canvasHeight = computed<number | null>(() => this.heigthTela()*0.5);\r\n\r\n      //? Largura e altura da área de corte\r\n      cutWidth = computed<number | null>(() => {\r\n        if(this._variaviesDialog()?.indCircle){\r\n          return this.radius()! * 2;\r\n        }else{\r\n          const canvasWidth = this.canvasWidth()!;\r\n          const maxWidth = canvasWidth * 0.8;\r\n          const proportionalHeight = maxWidth * this.proporcaoImagem()!;\r\n          return proportionalHeight > this.canvasHeight()! * 0.8 ? this.canvasHeight()! * 0.8 / this.proporcaoImagem()! : maxWidth;\r\n        }\r\n\r\n      });\r\n      cutHeight = computed<number | null>(() => {\r\n        if(this._variaviesDialog()?.indCircle){\r\n          return this.radius()! * 2;\r\n        }else{\r\n          const canvasHeight = this.canvasHeight()!;\r\n          const maxHeight = canvasHeight * 0.8;\r\n          const proportionalWidth = maxHeight / this.proporcaoImagem()!;\r\n          return proportionalWidth > this.canvasWidth()! * 0.8 ? this.canvasWidth()! * 0.8 * this.proporcaoImagem()! : maxHeight;\r\n        }\r\n\r\n      });\r\n\r\n      //? Largura e altura da imagem no canvas (baseado na escala) - tamanho real da imagem\r\n      canvaImageWidth = computed<number>(()=> {\r\n        return this._Image().width * this.scaleFactorReadOnly()!\r\n      })\r\n      canvaImageHeight = computed<number>(()=> {\r\n        return this._Image().height * this.scaleFactorReadOnly()!\r\n      })\r\n      proporcaoImagem = computed<number | null>(() => {\r\n        return this._variaviesDialog()?.height! / this._variaviesDialog()?.width!;\r\n      });\r\n\r\n      radius = computed<number | null>(() => {\r\n        const minSize =   Math.min(this.canvasHeight()!*0.8, this.canvasWidth()!*0.8 );\r\n        return minSize/2;\r\n      });\r\n\r\n    //#endregion\r\n\r\n    // #region Limites de movimentação da imagem\r\n    //? Limites de movimentação da imagem\r\n      indCircle = computed<boolean>(()=> {\r\n        return this._variaviesDialog()?.indCircle!\r\n      })\r\n\r\n      xMin = computed<number>(()=> {\r\n        return !this._variaviesDialog()?.indCircle! ? (this.canvasWidth()! -  this.cutWidth()!)/2 : (this.canvasWidth()! -  (this.radius()!*2))/2\r\n      })\r\n      yMin = computed<number>(()=> {\r\n        return !this._variaviesDialog()?.indCircle! ? (this.canvasHeight()! -  this.cutHeight()!)/2 : (this.canvasHeight()! -  (this.radius()!*2))/2\r\n      })\r\n\r\n      xMax = computed<number>(()=> {\r\n        return !this._variaviesDialog()?.indCircle! ? -( this.canvaImageWidth()! - (this.xMin()!) - this.cutWidth()!) : -( this.canvaImageWidth()! - (this.xMin()!) - (this.radius()!*2))\r\n      })\r\n      yMax = computed<number>(()=> {\r\n        return !this._variaviesDialog()?.indCircle! ? -( this.canvaImageHeight()! - (this.yMin()!) - this.cutHeight()!) : -( this.canvaImageHeight()! - (this.yMin()!) - (this.radius()!*2))\r\n      })\r\n    // #endregion\r\n\r\n\r\n\r\n    //? Proporção da imagem\r\n\r\n    widthTela = signal<number>(0)\r\n    heigthTela = signal<number>(0)\r\n\r\n\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.atualizaTamanhoTela()\r\n    this.updateCanvasSize();\r\n    this.atualizaCutBorder();\r\n  }\r\n\r\n  atualizaTamanhoTela(){\r\n    this.widthTela.set(window.innerWidth);\r\n    this.heigthTela.set(window.innerHeight);\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.recuperarVariaviesDialog()\r\n    this.inciarReferencias()\r\n    this.iniciarCanvas()\r\n  }\r\n  inciarReferencias(){\r\n    this.canvas.set(this.cropCanvas.nativeElement);\r\n    this.ctx.set(this.canvas()!.getContext('2d'))\r\n    this._Image().src = this._variaviesDialog()?.imagem!\r\n  }\r\n  iniciarCanvas(){\r\n      this._Image().onload = () => {\r\n\r\n      //? Define o tamanho do canvas\r\n      this.canvas()!.height = this.canvasHeight()!;\r\n      this.canvas()!.width = this.canvasWidth()!;\r\n\r\n\r\n      this.ajustarZommEPosicaoInicial()\r\n\r\n\r\n      this.initializeImageMove(this.canvas()!, this.ctx(), this._Image());\r\n      this.initializeMouseWheel(this.canvas()!, this.ctx(), this._Image());\r\n\r\n      this.redrawCanvas(this.ctx(), this._Image());\r\n\r\n    };\r\n  }\r\n\r\n  ajustarZommEPosicaoInicial(){\r\n    const cutWidth = this.cutWidth()!;\r\n    const cutHeight = this.cutHeight()!;\r\n    const imageWidth = this._Image().width;\r\n    const imageHeight = this._Image().height;\r\n\r\n    //? Ajusta possição e zoom inicial\r\n\r\n    if (this._variaviesDialog()?.indCircle) {\r\n      const scaleFactor = (this.radius()! * 2) / Math.min(imageWidth, imageHeight);\r\n      this.scaleFactorInicial.set(scaleFactor)\r\n      this.setScaleFactorModel(scaleFactor);\r\n    } else {\r\n      const scaleFactor = this.cutHeight()! === this.cutWidth()!\r\n        ? this._Image().width > this._Image().height\r\n          ? this.cutHeight()! / imageHeight\r\n          : this.cutWidth()! / imageWidth\r\n        : this.cutHeight()! > this.cutWidth()!\r\n          ? this.cutHeight()! / imageHeight\r\n          : this.cutWidth()! / imageWidth;\r\n      this.scaleFactorInicial.set(scaleFactor)\r\n      this.setScaleFactorModel(scaleFactor);\r\n\r\n    }\r\n\r\n    this.imageX = Math.max((this.canvas()!.width - imageWidth * this.scaleFactorReadOnly()!) / 2, this.xMin()!);\r\n    this.imageY = Math.max((this.canvasHeight()! - imageHeight * this.scaleFactorReadOnly()!) / 2, this.yMin()!);\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 atualizacao do canvas\r\n  //? Atualiza o tamanho do canvas\r\n  updateCanvasSize() {\r\n\r\n    this.imageX = (this.canvas()!.width - this._Image().width * this.scaleFactorReadOnly()!) / 2;\r\n    this.imageY = (this.canvasHeight()! / 2) - (this._Image().height * this.scaleFactorReadOnly()!) / 2;\r\n\r\n\r\n\r\n    this.canvas()!.height = this.canvasHeight()!;\r\n    this.canvas()!.width = this.canvasWidth()!;\r\n\r\n    this.redrawCanvas(this.ctx(), this._Image());\r\n  }\r\n\r\n  redrawCanvas(ctx: CanvasRenderingContext2D | null, img: HTMLImageElement) {\r\n    if (!ctx) return;\r\n\r\n    this.drawCropArea(ctx);\r\n\r\n    ctx.clearRect(0, 0, ctx.canvas.width, ctx.canvas.height);\r\n    ctx.filter = 'blur(5px) opacity(0.9)';\r\n    ctx.drawImage(img, this.imageX, this.imageY, img.width * this.scaleFactorReadOnly()!, img.height * this.scaleFactorReadOnly()!);\r\n    ctx.filter = 'none';\r\n\r\n    this.drawImageInCropArea(ctx, img);\r\n  }\r\n\r\n  //? Desenha a área de corte\r\n  drawCropArea(ctx: CanvasRenderingContext2D | null) {\r\n    if (!ctx) return;\r\n\r\n    this.atualizaCutBorder()\r\n\r\n    const cropX = ctx.canvas.width / 2 - this.cutWidth()! / 2;\r\n    const cropY = ctx.canvas.height / 2 - this.cutHeight()! / 2;\r\n\r\n\r\n    const cropXCircle = ctx.canvas.width / 2 - this.radius()! / 2;\r\n    const cropYCircle = ctx.canvas.height / 2 - this.radius()! / 2;\r\n\r\n    ctx.beginPath();\r\n    ctx.strokeStyle = 'transparent';\r\n    ctx.lineWidth = 2;\r\n\r\n    if(this._variaviesDialog()?.indCircle) {\r\n      ctx.arc(cropXCircle, cropYCircle, this.radius()!, 0, Math.PI * 2, true);\r\n    } else {\r\n      ctx.rect(cropX, cropY , this.cutWidth()!, this.cutHeight()!);\r\n    }\r\n\r\n    ctx.stroke();\r\n\r\n\r\n  }\r\n  //? Desenha a imagem na área de corte\r\n  drawImageInCropArea(ctx: CanvasRenderingContext2D | null, img: HTMLImageElement) {\r\n      if (!ctx) return;\r\n\r\n      const cropX = (ctx.canvas.width - this.cutWidth()!) / 2;\r\n      const cropY = (ctx.canvas.height - this.cutHeight()!) / 2;\r\n\r\n      ctx.save();\r\n      ctx.beginPath();\r\n\r\n      if(this._variaviesDialog()?.indCircle) {\r\n        ctx.arc(ctx.canvas.width/2, ctx.canvas.height/2, this.radius()!, 0, Math.PI * 2, true);\r\n\r\n      } else {\r\n        ctx.rect(cropX, cropY , this.cutWidth()!, this.cutHeight()!);\r\n      }\r\n\r\n      ctx.clip();\r\n      ctx.drawImage(img, this.imageX, this.imageY, img.width * this.scaleFactorReadOnly()!, img.height * this.scaleFactorReadOnly()!);\r\n      ctx.restore();\r\n  }\r\n  atualizaCutBorder() {\r\n    if (this.cropBorder && this.cropBorder.nativeElement) {\r\n      const cropBorderElement = this.cropBorder.nativeElement as HTMLElement;\r\n      if(this._variaviesDialog()?.indCircle){\r\n\r\n        cropBorderElement.style.borderRadius = this.radius()!*2+'px';\r\n        cropBorderElement.style.width = this.radius()!*2+'px';\r\n        cropBorderElement.style.height = this.radius()!*2+'px';\r\n      }else{\r\n        cropBorderElement.style.width = this.cutWidth()!+'px';\r\n        cropBorderElement.style.height = this.cutHeight()!+'px';\r\n      }\r\n    }\r\n  }\r\n  //#endregion\r\n\r\n\r\n  //#region handlers de eventos\r\n\r\n  comparadorOnZoomChange = this.scaleFactorInicial()!;\r\n  onZoomChange(e: any) {\r\n    const prevZoom = this.comparadorOnZoomChange;\r\n    const zoomValue = e.value;\r\n    this.comparadorOnZoomChange = e.value;\r\n    const direction: 'up' | 'down' = prevZoom < zoomValue ? 'up' : 'down';\r\n    this.ajustarZoom(direction, e.value);\r\n  }\r\n\r\n\r\n\r\n  initializeMouseWheel(canvas: HTMLCanvasElement, ctx: CanvasRenderingContext2D | null, img: HTMLImageElement) {\r\n    canvas.onwheel = (e) => {\r\n      e.preventDefault();\r\n      //? Recuperando os valores de zoom e delta atuais\r\n      const direction: 'up' | 'down' = e.deltaY > 0 ? 'down' : 'up';\r\n\r\n      this.ajustarZoom(direction)\r\n    };\r\n  }\r\n\r\n\r\n  ajustarZoom(direction: 'up' | 'down', value?: number) {\r\n    const prevScaleFactor = this.scaleFactorReadOnly()!;\r\n    const delta = direction == 'down' ? -0.015 : 0.015;\r\n\r\n    let scaleFactor = prevScaleFactor + (delta*1.4);\r\n\r\n    if(value)\r\n        scaleFactor = value+ this.scaleFactorInicial()!;\r\n\r\n    const newHeight = this._Image().height * scaleFactor;\r\n    const newWidth = this._Image().width * scaleFactor;\r\n\r\n    if (this._variaviesDialog()?.indCircle) {\r\n      if (newHeight < this.radius()! * 2 || newWidth < this.radius()! * 2) {\r\n        scaleFactor = prevScaleFactor;\r\n      } else {\r\n        this.scaleFactor.set(scaleFactor);\r\n        this.setScaleFactorModel(scaleFactor);\r\n      }\r\n    } else {\r\n      if (newHeight < this.cutHeight()! || newWidth < this.cutWidth()!) {\r\n        scaleFactor = prevScaleFactor;\r\n      } else {\r\n        this.scaleFactor.set(scaleFactor);\r\n        this.setScaleFactorModel(scaleFactor);\r\n      }\r\n    }\r\n\r\n    this.scaleFactor.set(scaleFactor);\r\n    this.setScaleFactorModel(scaleFactor);\r\n\r\n    const canvas = this.cropCanvas.nativeElement;\r\n    const canvasWidth = canvas.offsetWidth;\r\n    const canvasHeight = canvas.offsetHeight;\r\n    const centerX = canvasWidth / 2;\r\n    const centerY = canvasHeight / 2;\r\n    const newCanvasX = centerX - (centerX - this.imageX) * (scaleFactor / prevScaleFactor);\r\n    const newCanvasY = centerY - (centerY - this.imageY) * (scaleFactor / prevScaleFactor);\r\n    this.imageX = newCanvasX;\r\n    this.imageY = newCanvasY;\r\n\r\n    if (!this.verificaImagemdentroDosLimiteXmin()) {\r\n      const diffXmin = this.retornaDiffXmax();\r\n      this.moveImage(this.imageX - diffXmin);\r\n    }\r\n\r\n    if (!this.verificaImagemdentroDosLimiteXmax()) {\r\n      const diffXmax = this.retornaDiffXmin();\r\n      this.moveImage(this.imageX + diffXmax);\r\n    }\r\n\r\n    if (!this.verificaImagemdentroDosLimiteYmax()) {\r\n      const diffYmax = this.retornaDiffYmin();\r\n      this.moveImage(undefined, this.imageY + diffYmax);\r\n    }\r\n\r\n    if (!this.verificaImagemdentroDosLimiteYmin()) {\r\n      const diffYmin = this.retornaDiffYmax();\r\n      this.moveImage(undefined, this.imageY - diffYmin);\r\n    }\r\n    this.redrawCanvas(this.ctx()!, this._Image()!);\r\n  }\r\n\r\n\r\n\r\n\r\n  verificaImagemdentroDosLimiteXmin(): boolean {\r\n    const newImageX = this.imageX;\r\n    return newImageX < this.xMin()!\r\n  }\r\n  verificaImagemdentroDosLimiteXmax(): boolean {\r\n    const newImageX = this.imageX;\r\n    return newImageX > this.xMax()!\r\n  }\r\n  verificaImagemdentroDosLimiteYmin(): boolean {\r\n    const newImageY = this.imageY;\r\n    return newImageY < this.yMin()!\r\n  }\r\n  verificaImagemdentroDosLimiteYmax(): boolean {\r\n    const newImageY = this.imageY;\r\n    return newImageY > this.yMax()!\r\n  }\r\n\r\n  retornaDiffXmin(): number {\r\n    const newImageX = this.imageX;\r\n    return this.xMin()! - newImageX;\r\n  }\r\n  retornaDiffXmax(): number {\r\n    const newImageX = this.imageX;\r\n    return newImageX - this.xMax()!;\r\n  }\r\n  retornaDiffYmin(): number {\r\n    const newImageY = this.imageY;\r\n    return this.yMin()! - newImageY;\r\n  }\r\n  retornaDiffYmax(): number {\r\n    const newImageY = this.imageY;\r\n    return newImageY - this.yMax()!;\r\n  }\r\n\r\n\r\n  initializeImageMove(canvas: HTMLCanvasElement, ctx: CanvasRenderingContext2D | null, img: HTMLImageElement) {\r\n    let isDragging = false;\r\n\r\n    canvas.style.cursor = 'grab';\r\n\r\n    canvas.onmousedown = (e) => {\r\n      isDragging = true;\r\n      canvas.style.cursor = 'grabbing';\r\n      this.startX = e.offsetX - this.imageX;\r\n      this.startY = e.offsetY - this.imageY;\r\n    };\r\n\r\n    canvas.onmouseup = () => {\r\n      isDragging = false;\r\n      canvas.style.cursor = 'grab';\r\n    };\r\n\r\n    canvas.onmouseout = () => {\r\n      isDragging = false;\r\n      canvas.style.cursor = 'grab';\r\n    };\r\n\r\n    canvas.onmousemove = (e) => {\r\n      if (isDragging) {\r\n\r\n          // Calcula o novo posicionamento da imagem\r\n          let newImageX = e.offsetX - this.startX;\r\n          let newImageY = e.offsetY - this.startY;\r\n\r\n          if (newImageX <  this.xMin()! && newImageX > this.xMax()!) {\r\n            this.moveImage(newImageX)\r\n          }\r\n          if(newImageY < this.yMin()! && newImageY > this.yMax()!){\r\n            this.moveImage(undefined, newImageY)\r\n          }\r\n\r\n\r\n          this.redrawCanvas(ctx, img);\r\n      }\r\n    };\r\n\r\n\r\n  }\r\n\r\n  moveImage(dx?: number, dy?: number) {\r\n    this.imageX = (dx??this.imageX);\r\n    this.imageY = (dy??this.imageY);\r\n  }\r\n\r\n\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    const ctx = this.ctx();\r\n\r\n    if (ctx) {\r\n      const X = ((this.canvas()!.width - this._Image().width * this.scaleFactorReadOnly()!) / 2);\r\n      const Y = ((this.canvasHeight()! / 2) - (this._Image().height * this.scaleFactorReadOnly()!) / 2);\r\n\r\n      // Recuperar o imageData da imagem que está na área de corte\r\n      let imageData\r\n      const cropX = (ctx.canvas.width - this.cutWidth()!) / 2;\r\n      const cropY = (ctx.canvas.height - this.cutHeight()!) / 2;\r\n      if(this._variaviesDialog()?.indCircle){\r\n        // Create a new canvas with the same dimensions as the circle\r\n        const circleCanvas = document.createElement('canvas');\r\n        const circleCtx = circleCanvas.getContext('2d');\r\n        circleCanvas.width = this.radius()! * 2;\r\n        circleCanvas.height = this.radius()! * 2;\r\n\r\n        // Draw the circle on the new canvas\r\n        circleCtx!.beginPath();\r\n        circleCtx!.arc(this.radius()!, this.radius()!, this.radius()!, 0, 2 * Math.PI);\r\n        circleCtx!.fill();\r\n\r\n        // Set the composite operation to 'destination-in' to cut out the circle\r\n        ctx.globalCompositeOperation = 'destination-in';\r\n\r\n        // Draw the image on the main canvas using the circle as a mask\r\n        ctx.drawImage(circleCanvas, cropX, cropY);\r\n\r\n        // Reset the composite operation to the default value\r\n        ctx.globalCompositeOperation = 'source-over';\r\n\r\n        // Get the image data of the cropped circle\r\n        imageData = ctx.getImageData(cropX, cropY, this.radius()! * 2, this.radius()! * 2);\r\n      } else {\r\n        imageData = ctx.getImageData(cropX, cropY, this.cutWidth()!, this.cutHeight()!);\r\n      }\r\n\r\n\r\n      // Obter os valores de width e height da variável _variaviesDialog\r\n      const variaveisDialog = this._variaviesDialog();\r\n      if (variaveisDialog) {\r\n        const { width, height } = variaveisDialog;\r\n\r\n        // Criar um novo canvas e contexto com os valores de width e height\r\n        const newCanvas = document.createElement('canvas');\r\n        const newCtx = newCanvas.getContext('2d');\r\n        newCanvas.width = width;\r\n        newCanvas.height = height;\r\n\r\n        if (newCtx) {\r\n          // Redimensionar a imagem para o tamanho especificado\r\n          const tempCanvas = document.createElement('canvas');\r\n          const tempCtx = tempCanvas.getContext('2d');\r\n          tempCanvas.width = this.cutWidth()!;\r\n          tempCanvas.height = this.cutHeight()!;\r\n          tempCtx!.putImageData(imageData, 0, 0);\r\n\r\n          newCtx.drawImage(tempCanvas, 0, 0, width, height);\r\n\r\n          window.dispatchEvent(new CustomEvent('cropImage', { detail:{\r\n            result: Promise.resolve(newCanvas.toDataURL()),\r\n            status: true\r\n          } }));\r\n          this.closeCropModal();\r\n        }\r\n      }\r\n    }\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"]}
182
+ ImageCropperComponent
183
+ ], 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"]}