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.
- package/esm2022/lib/api/base-components/base-component-dropdown.mjs +2 -3
- package/esm2022/lib/api/services/image.cutter.service.mjs +71 -455
- package/esm2022/lib/components/kv-inputs/kv-tree-multi-select/kv-tree-multi-select.component.mjs +3 -3
- package/fesm2022/keevo-components.mjs +79 -459
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/package.json +3 -2
|
@@ -1,21 +1,16 @@
|
|
|
1
|
-
import { Component,
|
|
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 "
|
|
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
|
-
|
|
55
|
+
this.imageChangedEvent = null;
|
|
56
|
+
this.croppedImage = '';
|
|
57
|
+
//#region Variáveis de controle
|
|
63
58
|
this._variaviesDialog = signal(null);
|
|
64
|
-
|
|
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
|
-
|
|
149
|
-
this.
|
|
150
|
-
this.scaleFactor.set(valor);
|
|
61
|
+
fileChangeEvent(event) {
|
|
62
|
+
this.imageChangedEvent = event;
|
|
151
63
|
}
|
|
152
|
-
|
|
153
|
-
this.
|
|
154
|
-
this.updateCanvasSize();
|
|
155
|
-
this.atualizaCutBorder();
|
|
64
|
+
imageCropped(event) {
|
|
65
|
+
this.croppedImage = event.base64;
|
|
156
66
|
}
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
67
|
+
imageLoaded(image) { }
|
|
68
|
+
cropperReady() { }
|
|
69
|
+
loadImageFailed() { }
|
|
70
|
+
//#endregion
|
|
71
|
+
ngAfterContentInit() {
|
|
162
72
|
this.recuperarVariaviesDialog();
|
|
163
|
-
this.
|
|
164
|
-
this.
|
|
73
|
+
this.recuperaInstanciaDialog();
|
|
74
|
+
this.setAspectRatio();
|
|
165
75
|
}
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
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
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
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",
|
|
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
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
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
|
-
|
|
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
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
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
|
-
|
|
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
|
-
|
|
559
|
-
|
|
560
|
-
|
|
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"]}
|