UNPKG

162 kBJavaScriptView Raw
1import { __values } from 'tslib';
2import { Injectable, Component, Input, Output, EventEmitter, ViewChild, NgModule } from '@angular/core';
3import { fabric } from 'fabric';
4import { ActionSheetController, IonicModule } from 'ionic-angular';
5import { Gesture } from 'ionic-angular/gestures/gesture';
6import { TranslateService } from '@ngx-translate/core';
7import { CommonModule } from '@angular/common';
8
9/**
10 * @fileoverview added by tsickle
11 * @suppress {checkTypes} checked by tsc
12 */
13/** @enum {number} */
14var AvailableGeometricShape = {
15 "Rectangle": 0,
16 "Circle": 1,
17 "Triangle": 2,
18 "Line": 3,
19 "Cross": 4,
20};
21AvailableGeometricShape[AvailableGeometricShape["Rectangle"]] = "Rectangle";
22AvailableGeometricShape[AvailableGeometricShape["Circle"]] = "Circle";
23AvailableGeometricShape[AvailableGeometricShape["Triangle"]] = "Triangle";
24AvailableGeometricShape[AvailableGeometricShape["Line"]] = "Line";
25AvailableGeometricShape[AvailableGeometricShape["Cross"]] = "Cross";
26
27/**
28 * @fileoverview added by tsickle
29 * @suppress {checkTypes} checked by tsc
30 */
31var /** @type {?} */ SHAPE_DATA = {
32 width: 200,
33 height: 200,
34 left: 50,
35 top: 50,
36 radius: 100,
37 stroke: 10,
38 freeDrawingBrushWidth: 10,
39 cornerSize: 20
40};
41
42/**
43 * @fileoverview added by tsickle
44 * @suppress {checkTypes} checked by tsc
45 */
46var CanvasManagerService = /** @class */ (function () {
47 function CanvasManagerService() {
48 this.emptyCanvas();
49 this.mousePosition = { x: 0, y: 0 };
50 this.cropStartingPosition = { x: 0, y: 0 };
51 this.canvas.freeDrawingBrush.width = SHAPE_DATA.freeDrawingBrushWidth;
52 }
53 Object.defineProperty(CanvasManagerService.prototype, "backgroundImage", {
54 get: /**
55 * @return {?}
56 */
57 function () {
58 return this.canvas;
59 },
60 enumerable: true,
61 configurable: true
62 });
63 Object.defineProperty(CanvasManagerService.prototype, "canvasObjects", {
64 get: /**
65 * @return {?}
66 */
67 function () {
68 return this.canvas.getObjects();
69 },
70 enumerable: true,
71 configurable: true
72 });
73 Object.defineProperty(CanvasManagerService.prototype, "canvasBackgroundImage", {
74 get: /**
75 * @return {?}
76 */
77 function () {
78 return this.canvas.backgroundImage;
79 },
80 enumerable: true,
81 configurable: true
82 });
83 Object.defineProperty(CanvasManagerService.prototype, "activeObject", {
84 get: /**
85 * @return {?}
86 */
87 function () {
88 return this.canvas.getActiveObject();
89 },
90 enumerable: true,
91 configurable: true
92 });
93 Object.defineProperty(CanvasManagerService.prototype, "activeGroup", {
94 get: /**
95 * @return {?}
96 */
97 function () {
98 return this.canvas.getActiveObjects();
99 },
100 enumerable: true,
101 configurable: true
102 });
103 /**
104 * @return {?}
105 */
106 CanvasManagerService.prototype.emptyCanvas = /**
107 * @return {?}
108 */
109 function () {
110 if (this.canvas) {
111 this.canvas.dispose();
112 }
113 this.canvas = new fabric.Canvas('canvas');
114 this.canvas.clear();
115 this.canvas.remove(this.canvas.getObjects());
116 };
117 /**
118 * @param {?=} backgroundImageURL
119 * @return {?}
120 */
121 CanvasManagerService.prototype.loadNewImage = /**
122 * @param {?=} backgroundImageURL
123 * @return {?}
124 */
125 function (backgroundImageURL) {
126 this.emptyCanvas();
127 if (backgroundImageURL) {
128 this.setBackgroundFromURL(backgroundImageURL);
129 }
130 };
131 /**
132 * @return {?}
133 */
134 CanvasManagerService.prototype.renderCanvas = /**
135 * @return {?}
136 */
137 function () {
138 this.markSelectedObjectsDirty();
139 this.canvas.renderAll();
140 };
141 /**
142 * @param {?} strokeColor
143 * @param {?} fillColor
144 * @param {?} shape
145 * @return {?}
146 */
147 CanvasManagerService.prototype.addGeometricShape = /**
148 * @param {?} strokeColor
149 * @param {?} fillColor
150 * @param {?} shape
151 * @return {?}
152 */
153 function (strokeColor, fillColor, shape) {
154 switch (shape) {
155 case AvailableGeometricShape.Rectangle:
156 this.addRectangle(strokeColor, fillColor);
157 break;
158 case AvailableGeometricShape.Circle:
159 this.addCircle(strokeColor, fillColor);
160 break;
161 case AvailableGeometricShape.Triangle:
162 this.addTriangle(strokeColor, fillColor);
163 break;
164 case AvailableGeometricShape.Line:
165 this.addHorizontalLine(strokeColor, fillColor);
166 break;
167 case AvailableGeometricShape.Cross:
168 this.addCross(strokeColor, fillColor);
169 break;
170 }
171 };
172 /**
173 * @param {?} strokeColor
174 * @param {?} fillColor
175 * @return {?}
176 */
177 CanvasManagerService.prototype.addRectangle = /**
178 * @param {?} strokeColor
179 * @param {?} fillColor
180 * @return {?}
181 */
182 function (strokeColor, fillColor) {
183 this.canvas.add(new fabric.Rect({
184 width: SHAPE_DATA.width,
185 height: SHAPE_DATA.height,
186 left: SHAPE_DATA.left,
187 top: SHAPE_DATA.top,
188 fill: fillColor,
189 stroke: strokeColor,
190 strokeWidth: SHAPE_DATA.stroke,
191 cornerSize: SHAPE_DATA.cornerSize
192 }));
193 };
194 /**
195 * @param {?} strokeColor
196 * @param {?} fillColor
197 * @return {?}
198 */
199 CanvasManagerService.prototype.addCircle = /**
200 * @param {?} strokeColor
201 * @param {?} fillColor
202 * @return {?}
203 */
204 function (strokeColor, fillColor) {
205 this.canvas.add(new fabric.Circle({
206 left: SHAPE_DATA.left,
207 top: SHAPE_DATA.top,
208 radius: SHAPE_DATA.radius,
209 stroke: strokeColor,
210 strokeWidth: SHAPE_DATA.stroke,
211 fill: fillColor,
212 cornerSize: SHAPE_DATA.cornerSize
213 }));
214 };
215 /**
216 * @param {?} strokeColor
217 * @param {?} fillColor
218 * @return {?}
219 */
220 CanvasManagerService.prototype.addTriangle = /**
221 * @param {?} strokeColor
222 * @param {?} fillColor
223 * @return {?}
224 */
225 function (strokeColor, fillColor) {
226 this.canvas.add(new fabric.Triangle({
227 width: SHAPE_DATA.width,
228 height: SHAPE_DATA.height,
229 left: SHAPE_DATA.left,
230 top: SHAPE_DATA.top,
231 fill: fillColor,
232 stroke: strokeColor,
233 strokeWidth: SHAPE_DATA.stroke,
234 cornerSize: SHAPE_DATA.cornerSize
235 }));
236 };
237 /**
238 * @param {?} strokeColor
239 * @param {?} fillColor
240 * @return {?}
241 */
242 CanvasManagerService.prototype.addHorizontalLine = /**
243 * @param {?} strokeColor
244 * @param {?} fillColor
245 * @return {?}
246 */
247 function (strokeColor, fillColor) {
248 this.canvas.add(this.createHorizontalLine(strokeColor));
249 };
250 /**
251 * @param {?} strokeColor
252 * @return {?}
253 */
254 CanvasManagerService.prototype.createHorizontalLine = /**
255 * @param {?} strokeColor
256 * @return {?}
257 */
258 function (strokeColor) {
259 var /** @type {?} */ line = new fabric.Line([100, 150, 200, 150], {
260 left: 50,
261 top: 100,
262 stroke: strokeColor,
263 strokeWidth: 5,
264 cornerSize: SHAPE_DATA.cornerSize
265 });
266 line.setControlsVisibility({
267 bl: false,
268 br: false,
269 tl: false,
270 tr: false,
271 mt: false,
272 mb: false
273 });
274 return line;
275 };
276 /**
277 * @param {?} strokeColor
278 * @return {?}
279 */
280 CanvasManagerService.prototype.createVerticalLine = /**
281 * @param {?} strokeColor
282 * @return {?}
283 */
284 function (strokeColor) {
285 var /** @type {?} */ line = new fabric.Line([150, 100, 150, 200], {
286 left: 100,
287 top: 50,
288 stroke: strokeColor,
289 strokeWidth: 5,
290 cornerSize: SHAPE_DATA.cornerSize
291 });
292 line.setControlsVisibility({
293 bl: false,
294 br: false,
295 tl: false,
296 tr: false,
297 ml: false,
298 mr: false
299 });
300 return line;
301 };
302 /**
303 * @param {?} strokeColor
304 * @param {?} fillColor
305 * @return {?}
306 */
307 CanvasManagerService.prototype.addCross = /**
308 * @param {?} strokeColor
309 * @param {?} fillColor
310 * @return {?}
311 */
312 function (strokeColor, fillColor) {
313 var /** @type {?} */ horizontalLine = this.createHorizontalLine(strokeColor);
314 var /** @type {?} */ verticalLine = this.createVerticalLine(strokeColor);
315 this.canvas.add(horizontalLine);
316 this.canvas.add(verticalLine);
317 };
318 /**
319 * @return {?}
320 */
321 CanvasManagerService.prototype.toggleFreeDrawing = /**
322 * @return {?}
323 */
324 function () {
325 this.canvas.isDrawingMode = !this.canvas.isDrawingMode;
326 };
327 /**
328 * @param {?} color
329 * @return {?}
330 */
331 CanvasManagerService.prototype.setFreeDrawingBrushColor = /**
332 * @param {?} color
333 * @return {?}
334 */
335 function (color) {
336 this.canvas.freeDrawingBrush.color = color;
337 };
338 Object.defineProperty(CanvasManagerService.prototype, "freeDrawingBrushWidthFromZoom", {
339 set: /**
340 * @param {?} zoom
341 * @return {?}
342 */
343 function (zoom) {
344 this.canvas.freeDrawingBrush.width = SHAPE_DATA.freeDrawingBrushWidth * (1 / zoom);
345 },
346 enumerable: true,
347 configurable: true
348 });
349 /**
350 * @param {?} color
351 * @param {?} inputText
352 * @return {?}
353 */
354 CanvasManagerService.prototype.addText = /**
355 * @param {?} color
356 * @param {?} inputText
357 * @return {?}
358 */
359 function (color, inputText) {
360 var /** @type {?} */ text = new fabric.IText('text', {
361 fontFamily: 'arial black',
362 fontStyle: 'bold',
363 left: SHAPE_DATA.left,
364 top: SHAPE_DATA.top,
365 cornerSize: SHAPE_DATA.cornerSize
366 });
367 text.setColor(color);
368 this.canvas.add(text);
369 };
370 /**
371 * @param {?} imageURL
372 * @return {?}
373 */
374 CanvasManagerService.prototype.addImage = /**
375 * @param {?} imageURL
376 * @return {?}
377 */
378 function (imageURL) {
379 var _this = this;
380 return new Promise(function (resolve, reject) {
381 var /** @type {?} */ canvas = _this.canvas;
382 var /** @type {?} */ image = new Image();
383 image.onload = function (img) {
384 var /** @type {?} */ fabricImage = new fabric.Image(image, {
385 angle: 0,
386 width: image.width,
387 height: image.height,
388 left: SHAPE_DATA.left,
389 top: SHAPE_DATA.top,
390 scaleX: 1,
391 scaleY: 1,
392 cornerSize: SHAPE_DATA.cornerSize
393 });
394 canvas.add(fabricImage);
395 resolve();
396 };
397 image.src = imageURL;
398 });
399 };
400 /**
401 * @param {?} backgroundImageURL
402 * @return {?}
403 */
404 CanvasManagerService.prototype.setBackgroundFromURL = /**
405 * @param {?} backgroundImageURL
406 * @return {?}
407 */
408 function (backgroundImageURL) {
409 var /** @type {?} */ canvas = this.canvas;
410 var /** @type {?} */ resize = this.resizeCanvasAndComputeScaleFactor;
411 return new Promise(function (resolve, reject) {
412 if (backgroundImageURL == null) {
413 return reject();
414 }
415 var /** @type {?} */ image = new Image();
416 image.onload = function () {
417 var /** @type {?} */ f_img = new fabric.Image(image, {});
418 var /** @type {?} */ scaleData = resize(f_img, canvas);
419 canvas.setBackgroundImage(f_img, canvas.renderAll.bind(canvas), {
420 scaleX: scaleData.scaleFactor,
421 scaleY: scaleData.scaleFactor
422 });
423 canvas.renderAll();
424 resolve();
425 };
426 image.src = backgroundImageURL;
427 });
428 };
429 /**
430 * @param {?} f_img
431 * @param {?} canvas
432 * @return {?}
433 */
434 CanvasManagerService.prototype.resizeCanvasAndComputeScaleFactor = /**
435 * @param {?} f_img
436 * @param {?} canvas
437 * @return {?}
438 */
439 function (f_img, canvas) {
440 var /** @type {?} */ container = document.getElementsByClassName('div-canvas-container')[0];
441 canvas.setWidth(container.clientWidth);
442 canvas.setHeight(container.clientHeight);
443 var /** @type {?} */ canvasWidth = canvas.getWidth();
444 var /** @type {?} */ canvasHeight = canvas.getHeight();
445 var /** @type {?} */ canvasAspect = canvasWidth / canvasHeight;
446 var /** @type {?} */ imgAspect = f_img.width / f_img.height;
447 var /** @type {?} */ left, /** @type {?} */ top, /** @type {?} */ scaleFactor;
448 if (canvasAspect <= imgAspect) {
449 scaleFactor = canvasWidth / f_img.width;
450 left = 0;
451 top = -(f_img.height * scaleFactor - canvasHeight) / 2;
452 }
453 else {
454 scaleFactor = canvasHeight / f_img.height;
455 top = 0;
456 left = -(f_img.width * scaleFactor - canvasWidth) / 2;
457 }
458 return { scaleFactor: scaleFactor, left: left, top: top };
459 };
460 /**
461 * @return {?}
462 */
463 CanvasManagerService.prototype.onOrientationChange = /**
464 * @return {?}
465 */
466 function () {
467 this.mousePosition = { x: this.canvas.getWidth, y: this.canvas.getHeight };
468 this.cropImage();
469 };
470 /**
471 * @param {?} color
472 * @return {?}
473 */
474 CanvasManagerService.prototype.changeSelectedObjectsFillColor = /**
475 * @param {?} color
476 * @return {?}
477 */
478 function (color) {
479 var /** @type {?} */ activeObjects = this.canvas.getActiveObjects();
480 if (activeObjects) {
481 try {
482 for (var activeObjects_1 = __values(activeObjects), activeObjects_1_1 = activeObjects_1.next(); !activeObjects_1_1.done; activeObjects_1_1 = activeObjects_1.next()) {
483 var object = activeObjects_1_1.value;
484 object.setColor(color);
485 this.canvas.renderAll();
486 }
487 }
488 catch (e_1_1) { e_1 = { error: e_1_1 }; }
489 finally {
490 try {
491 if (activeObjects_1_1 && !activeObjects_1_1.done && (_a = activeObjects_1.return)) _a.call(activeObjects_1);
492 }
493 finally { if (e_1) throw e_1.error; }
494 }
495 }
496 var e_1, _a;
497 };
498 /**
499 * @param {?} color
500 * @return {?}
501 */
502 CanvasManagerService.prototype.changeSelectedObjectsStrokeColor = /**
503 * @param {?} color
504 * @return {?}
505 */
506 function (color) {
507 var /** @type {?} */ activeObjects = this.canvas.getActiveObjects();
508 if (activeObjects) {
509 try {
510 for (var activeObjects_2 = __values(activeObjects), activeObjects_2_1 = activeObjects_2.next(); !activeObjects_2_1.done; activeObjects_2_1 = activeObjects_2.next()) {
511 var object = activeObjects_2_1.value;
512 if (object.type === 'i-text') {
513 object.setColor(color);
514 }
515 else {
516 object.stroke = color;
517 object.set('dirty', true);
518 }
519 }
520 }
521 catch (e_2_1) { e_2 = { error: e_2_1 }; }
522 finally {
523 try {
524 if (activeObjects_2_1 && !activeObjects_2_1.done && (_a = activeObjects_2.return)) _a.call(activeObjects_2);
525 }
526 finally { if (e_2) throw e_2.error; }
527 }
528 this.canvas.renderAll();
529 }
530 var e_2, _a;
531 };
532 /**
533 * @return {?}
534 */
535 CanvasManagerService.prototype.deleteSelectedObjects = /**
536 * @return {?}
537 */
538 function () {
539 var /** @type {?} */ activeObjects = this.canvas.getActiveObjects();
540 if (activeObjects) {
541 try {
542 for (var activeObjects_3 = __values(activeObjects), activeObjects_3_1 = activeObjects_3.next(); !activeObjects_3_1.done; activeObjects_3_1 = activeObjects_3.next()) {
543 var object = activeObjects_3_1.value;
544 this.canvas.remove(object);
545 }
546 }
547 catch (e_3_1) { e_3 = { error: e_3_1 }; }
548 finally {
549 try {
550 if (activeObjects_3_1 && !activeObjects_3_1.done && (_a = activeObjects_3.return)) _a.call(activeObjects_3);
551 }
552 finally { if (e_3) throw e_3.error; }
553 }
554 this.canvas.discardActiveObject();
555 this.canvas.renderAll();
556 }
557 var e_3, _a;
558 };
559 /**
560 * @return {?}
561 */
562 CanvasManagerService.prototype.bringSelectedObjectsToFront = /**
563 * @return {?}
564 */
565 function () {
566 var /** @type {?} */ activeObjects = this.canvas.getActiveObjects();
567 if (activeObjects) {
568 try {
569 for (var activeObjects_4 = __values(activeObjects), activeObjects_4_1 = activeObjects_4.next(); !activeObjects_4_1.done; activeObjects_4_1 = activeObjects_4.next()) {
570 var object = activeObjects_4_1.value;
571 this.canvas.bringToFront(object);
572 }
573 }
574 catch (e_4_1) { e_4 = { error: e_4_1 }; }
575 finally {
576 try {
577 if (activeObjects_4_1 && !activeObjects_4_1.done && (_a = activeObjects_4.return)) _a.call(activeObjects_4);
578 }
579 finally { if (e_4) throw e_4.error; }
580 }
581 }
582 var e_4, _a;
583 };
584 /**
585 * @return {?}
586 */
587 CanvasManagerService.prototype.sendSelectedObjectsToBack = /**
588 * @return {?}
589 */
590 function () {
591 var /** @type {?} */ activeObjects = this.canvas.getActiveObjects();
592 if (activeObjects) {
593 try {
594 for (var activeObjects_5 = __values(activeObjects), activeObjects_5_1 = activeObjects_5.next(); !activeObjects_5_1.done; activeObjects_5_1 = activeObjects_5.next()) {
595 var object = activeObjects_5_1.value;
596 this.canvas.sendToBack(object);
597 }
598 }
599 catch (e_5_1) { e_5 = { error: e_5_1 }; }
600 finally {
601 try {
602 if (activeObjects_5_1 && !activeObjects_5_1.done && (_a = activeObjects_5.return)) _a.call(activeObjects_5);
603 }
604 finally { if (e_5) throw e_5.error; }
605 }
606 }
607 var e_5, _a;
608 };
609 /**
610 * @return {?}
611 */
612 CanvasManagerService.prototype.jsonFromCanvas = /**
613 * @return {?}
614 */
615 function () {
616 return this.canvas.toJSON();
617 };
618 /**
619 * @param {?} json
620 * @return {?}
621 */
622 CanvasManagerService.prototype.loadfromJson = /**
623 * @param {?} json
624 * @return {?}
625 */
626 function (json) {
627 var _this = this;
628 var /** @type {?} */ container = document.getElementsByClassName('div-canvas-container')[0];
629 this.canvas.setWidth(container.clientWidth);
630 this.canvas.setHeight(container.clientHeight);
631 return new Promise(function (resolve, reject) {
632 _this.adjustCanvas(json);
633 _this.canvas.loadFromJSON(json, _this.canvas.renderAll.bind(_this.canvas));
634 resolve();
635 });
636 };
637 /**
638 * @param {?} json
639 * @return {?}
640 */
641 CanvasManagerService.prototype.adjustCanvas = /**
642 * @param {?} json
643 * @return {?}
644 */
645 function (json) {
646 var /** @type {?} */ backgroundImage = json['backgroundImage'];
647 var /** @type {?} */ container = document.getElementsByClassName('div-canvas-container')[0];
648 var /** @type {?} */ width = backgroundImage['width'];
649 var /** @type {?} */ height = backgroundImage['height'];
650 var /** @type {?} */ canvasWidth = container.clientWidth;
651 var /** @type {?} */ canvasHeight = container.clientHeight;
652 var /** @type {?} */ canvasAspect = canvasWidth / canvasHeight;
653 var /** @type {?} */ imgAspect = width / height;
654 var /** @type {?} */ scaleFactor;
655 if (canvasAspect <= imgAspect) {
656 scaleFactor = canvasWidth / width;
657 }
658 else {
659 scaleFactor = canvasHeight / height;
660 }
661 var /** @type {?} */ objectScale = scaleFactor / backgroundImage['scaleX'];
662 backgroundImage['scaleX'] = scaleFactor;
663 backgroundImage['scaleY'] = scaleFactor;
664 this.canvas.setWidth(width * scaleFactor);
665 this.canvas.setHeight(height * scaleFactor);
666 var /** @type {?} */ objects = json['objects'];
667 for (var /** @type {?} */ i = 0; i < objects.length; i++) {
668 objects[i]['left'] *= objectScale;
669 objects[i]['top'] *= objectScale;
670 objects[i]['scaleX'] *= objectScale;
671 objects[i]['scaleY'] *= objectScale;
672 }
673 this.canvas.selectable = true;
674 this.canvas.selection = true;
675 this.canvas.renderAll();
676 };
677 /**
678 * @return {?}
679 */
680 CanvasManagerService.prototype.exportImageAsDataURL = /**
681 * @return {?}
682 */
683 function () {
684 return this.canvas.toDataURL('image/png');
685 };
686 /**
687 * @param {?} itemNumber
688 * @return {?}
689 */
690 CanvasManagerService.prototype.selectItem = /**
691 * @param {?} itemNumber
692 * @return {?}
693 */
694 function (itemNumber) {
695 this.canvas.setActiveObject(this.canvas.item(itemNumber));
696 };
697 /**
698 * @param {?} activeObject
699 * @return {?}
700 */
701 CanvasManagerService.prototype.getIndexOf = /**
702 * @param {?} activeObject
703 * @return {?}
704 */
705 function (activeObject) {
706 return this.canvas.getObjects().indexOf(activeObject);
707 };
708 /**
709 * @return {?}
710 */
711 CanvasManagerService.prototype.selectLastObject = /**
712 * @return {?}
713 */
714 function () {
715 var /** @type {?} */ itemNumber = this.canvas.getObjects().length - 1;
716 var /** @type {?} */ object = this.canvas.item(itemNumber);
717 this.canvas.setActiveObject(object);
718 object.enterEditing();
719 };
720 /**
721 * @return {?}
722 */
723 CanvasManagerService.prototype.markSelectedObjectsDirty = /**
724 * @return {?}
725 */
726 function () {
727 var /** @type {?} */ activeObjects = this.canvas.getActiveObjects();
728 if (activeObjects) {
729 try {
730 for (var activeObjects_6 = __values(activeObjects), activeObjects_6_1 = activeObjects_6.next(); !activeObjects_6_1.done; activeObjects_6_1 = activeObjects_6.next()) {
731 var object = activeObjects_6_1.value;
732 object.set('dirty', true);
733 }
734 }
735 catch (e_6_1) { e_6 = { error: e_6_1 }; }
736 finally {
737 try {
738 if (activeObjects_6_1 && !activeObjects_6_1.done && (_a = activeObjects_6.return)) _a.call(activeObjects_6);
739 }
740 finally { if (e_6) throw e_6.error; }
741 }
742 }
743 var e_6, _a;
744 };
745 /**
746 * @return {?}
747 */
748 CanvasManagerService.prototype.addSelectionRectangle = /**
749 * @return {?}
750 */
751 function () {
752 this.cropRectangle = new fabric.Rect({
753 fill: 'transparent',
754 originX: 'left',
755 originY: 'top',
756 stroke: '#ccc',
757 strokeDashArray: [2, 2],
758 opacity: 1,
759 width: 1,
760 height: 1
761 });
762 this.cropRectangle.visible = false;
763 this.canvas.add(this.cropRectangle);
764 };
765 /**
766 * @param {?} event
767 * @return {?}
768 */
769 CanvasManagerService.prototype.ajustCropRectangleFromMouse = /**
770 * @param {?} event
771 * @return {?}
772 */
773 function (event) {
774 var /** @type {?} */ x = Math.min(event.layerX, this.mousePosition.x), /** @type {?} */
775 y = Math.min(event.layerY, this.mousePosition.y), /** @type {?} */
776 w = Math.abs(event.layerX - this.mousePosition.x), /** @type {?} */
777 h = Math.abs(event.layerY - this.mousePosition.y);
778 if (!w || !h) {
779 return false;
780 }
781 this.cropRectangle
782 .set('top', y)
783 .set('left', x)
784 .set('width', w)
785 .set('height', h);
786 this.canvas.renderAll();
787 return true;
788 };
789 /**
790 * @param {?} event
791 * @return {?}
792 */
793 CanvasManagerService.prototype.startSelectingCropRectangleFromMouse = /**
794 * @param {?} event
795 * @return {?}
796 */
797 function (event) {
798 this.cropStartingPosition = { x: this.canvas.left, y: this.canvas.top };
799 this.cropRectangle.left = event.layerX;
800 this.cropRectangle.top = event.layerY;
801 this.cropRectangle.setCoords();
802 this.mousePosition = { x: event.layerX, y: event.layerY };
803 this.canvas.renderAll();
804 this.cropRectangle.visible = true;
805 this.canvas.bringToFront(this.cropRectangle);
806 };
807 /**
808 * @return {?}
809 */
810 CanvasManagerService.prototype.cropImage = /**
811 * @return {?}
812 */
813 function () {
814 var /** @type {?} */ left = this.cropRectangle.left;
815 var /** @type {?} */ top = this.cropRectangle.top;
816 var /** @type {?} */ width = this.cropRectangle.width;
817 var /** @type {?} */ height = this.cropRectangle.height;
818 var /** @type {?} */ container = document.getElementsByClassName('div-canvas-container')[0];
819 var /** @type {?} */ canvasWidth = container.clientWidth;
820 var /** @type {?} */ canvasHeight = container.clientHeight;
821 var /** @type {?} */ canvasAspect = canvasWidth / canvasHeight;
822 var /** @type {?} */ imgAspect = width / height;
823 var /** @type {?} */ scaleFactor;
824 if (canvasAspect <= imgAspect) {
825 scaleFactor = canvasWidth / width;
826 }
827 else {
828 scaleFactor = canvasHeight / height;
829 }
830 this.canvas.setWidth(width * scaleFactor);
831 this.canvas.setHeight(height * scaleFactor);
832 this.canvas.backgroundImage.scaleX *= scaleFactor;
833 this.canvas.backgroundImage.scaleY *= scaleFactor;
834 this.canvas.backgroundImage.left -= left;
835 this.canvas.backgroundImage.left *= scaleFactor;
836 this.canvas.backgroundImage.top -= top - scaleFactor;
837 this.canvas.backgroundImage.top *= scaleFactor;
838 this.moveAllObjectsInCanvas(-1 * left, -1 * top, scaleFactor);
839 this.canvas.selectable = true;
840 this.canvas.selection = true;
841 this.cropRectangle.visible = false;
842 this.canvas.remove(this.cropRectangle);
843 this.canvas.renderAll();
844 };
845 /**
846 * @param {?} event
847 * @return {?}
848 */
849 CanvasManagerService.prototype.ajustCropRectangle = /**
850 * @param {?} event
851 * @return {?}
852 */
853 function (event) {
854 var /** @type {?} */ touch = event.touches[0];
855 var /** @type {?} */ rect = event.target.getBoundingClientRect();
856 var /** @type {?} */ x = Math.min(touch.clientX - rect.left, this.mousePosition.x), /** @type {?} */
857 y = Math.min(touch.clientY - rect.top, this.mousePosition.y), /** @type {?} */
858 w = Math.abs(touch.clientX - rect.left - this.mousePosition.x), /** @type {?} */
859 h = Math.abs(touch.clientY - rect.top - this.mousePosition.y);
860 if (!w || !h) {
861 return false;
862 }
863 this.cropRectangle
864 .set('left', x)
865 .set('top', y)
866 .set('width', w)
867 .set('height', h);
868 this.canvas.renderAll();
869 return true;
870 };
871 /**
872 * @param {?} event
873 * @return {?}
874 */
875 CanvasManagerService.prototype.startSelectingCropRectangle = /**
876 * @param {?} event
877 * @return {?}
878 */
879 function (event) {
880 this.cropStartingPosition = { x: this.canvas.left, y: this.canvas.top };
881 var /** @type {?} */ touch = event.touches[0];
882 var /** @type {?} */ rect = event.target.getBoundingClientRect();
883 this.cropRectangle.left = touch.clientX - rect.left;
884 this.cropRectangle.top = touch.clientY - rect.top;
885 this.cropRectangle.setCoords();
886 this.mousePosition = { x: touch.clientX - rect.left, y: touch.clientY - rect.top };
887 this.canvas.renderAll();
888 this.cropRectangle.visible = true;
889 this.canvas.bringToFront(this.cropRectangle);
890 };
891 /**
892 * @return {?}
893 */
894 CanvasManagerService.prototype.disableSelection = /**
895 * @return {?}
896 */
897 function () {
898 this.canvas.selection = false;
899 };
900 /**
901 * @param {?} x
902 * @param {?} y
903 * @param {?} scaleFactor
904 * @return {?}
905 */
906 CanvasManagerService.prototype.moveAllObjectsInCanvas = /**
907 * @param {?} x
908 * @param {?} y
909 * @param {?} scaleFactor
910 * @return {?}
911 */
912 function (x, y, scaleFactor) {
913 var /** @type {?} */ objects = this.canvas.getObjects();
914 try {
915 for (var objects_1 = __values(objects), objects_1_1 = objects_1.next(); !objects_1_1.done; objects_1_1 = objects_1.next()) {
916 var obj = objects_1_1.value;
917 obj.left += x;
918 obj.left *= scaleFactor;
919 obj.scaleX *= scaleFactor;
920 obj.top += y;
921 obj.scaleY *= scaleFactor;
922 obj.top *= scaleFactor;
923 obj.setCoords();
924 }
925 }
926 catch (e_7_1) { e_7 = { error: e_7_1 }; }
927 finally {
928 try {
929 if (objects_1_1 && !objects_1_1.done && (_a = objects_1.return)) _a.call(objects_1);
930 }
931 finally { if (e_7) throw e_7.error; }
932 }
933 var e_7, _a;
934 };
935 /**
936 * @return {?}
937 */
938 CanvasManagerService.prototype.groupSelectedObjects = /**
939 * @return {?}
940 */
941 function () {
942 var /** @type {?} */ activeObjects = this.canvas.getActiveObjects();
943 if (activeObjects) {
944 var /** @type {?} */ objects = [];
945 try {
946 for (var activeObjects_7 = __values(activeObjects), activeObjects_7_1 = activeObjects_7.next(); !activeObjects_7_1.done; activeObjects_7_1 = activeObjects_7.next()) {
947 var object = activeObjects_7_1.value;
948 objects.push(object);
949 }
950 }
951 catch (e_8_1) { e_8 = { error: e_8_1 }; }
952 finally {
953 try {
954 if (activeObjects_7_1 && !activeObjects_7_1.done && (_a = activeObjects_7.return)) _a.call(activeObjects_7);
955 }
956 finally { if (e_8) throw e_8.error; }
957 }
958 this.deleteSelectedObjects();
959 var /** @type {?} */ group = new fabric.Group(objects);
960 this.canvas.add(group);
961 group.setCoords();
962 this.canvas.setActiveObject(group);
963 this.canvas.renderAll();
964 }
965 var e_8, _a;
966 };
967 /**
968 * @param {?} event
969 * @return {?}
970 */
971 CanvasManagerService.prototype.setLastPanPosition = /**
972 * @param {?} event
973 * @return {?}
974 */
975 function (event) {
976 this.lastPanPosition = new fabric.Point(event.touches[0].clientX, event.touches[0].clientY);
977 };
978 /**
979 * @param {?} event
980 * @return {?}
981 */
982 CanvasManagerService.prototype.panCanvas = /**
983 * @param {?} event
984 * @return {?}
985 */
986 function (event) {
987 var /** @type {?} */ delta = new fabric.Point(event.touches[0].clientX - this.lastPanPosition.x, event.touches[0].clientY - this.lastPanPosition.y);
988 this.canvas.relativePan(delta);
989 this.preventPanOutsideCanvas();
990 this.canvas.renderAll();
991 this.setLastPanPosition(event);
992 };
993 /**
994 * @return {?}
995 */
996 CanvasManagerService.prototype.preventPanOutsideCanvas = /**
997 * @return {?}
998 */
999 function () {
1000 var /** @type {?} */ canvasViewPort = this.canvas.viewportTransform;
1001 var /** @type {?} */ imageHeight = this.canvas.height * canvasViewPort[0];
1002 var /** @type {?} */ imageWidth = this.canvas.width * canvasViewPort[0];
1003 var /** @type {?} */ bottomEndPoint = this.canvas.height * (canvasViewPort[0] - 1);
1004 if (canvasViewPort[5] >= 0 || -bottomEndPoint > canvasViewPort[5]) {
1005 canvasViewPort[5] = (canvasViewPort[5] >= 0) ? 0 : -bottomEndPoint;
1006 }
1007 var /** @type {?} */ rightEndPoint = this.canvas.width * (canvasViewPort[0] - 1);
1008 if (canvasViewPort[4] >= 0 || -rightEndPoint > canvasViewPort[4]) {
1009 canvasViewPort[4] = (canvasViewPort[4] >= 0) ? 0 : -rightEndPoint;
1010 }
1011 };
1012 /**
1013 * @param {?} event
1014 * @return {?}
1015 */
1016 CanvasManagerService.prototype.zoom = /**
1017 * @param {?} event
1018 * @return {?}
1019 */
1020 function (event) {
1021 var /** @type {?} */ point = new fabric.Point(event.center.x, event.center.y);
1022 var /** @type {?} */ zoom = this.canvas.getZoom();
1023 if (event.additionalEvent === 'pinchout') {
1024 zoom *= 1.05;
1025 }
1026 if (event.additionalEvent === 'pinchin') {
1027 zoom /= 1.05;
1028 }
1029 if (zoom < 1) {
1030 zoom = 1;
1031 this.canvas.zoomToPoint(new fabric.Point(0, 0), zoom);
1032 this.canvas.absolutePan(new fabric.Point(0, 0));
1033 }
1034 else {
1035 if (zoom > 10) {
1036 zoom = 10;
1037 }
1038 this.canvas.zoomToPoint(point, zoom);
1039 }
1040 this.freeDrawingBrushWidthFromZoom(zoom);
1041 this.canvas.renderAll();
1042 };
1043 CanvasManagerService.decorators = [
1044 { type: Injectable },
1045 ];
1046 /** @nocollapse */
1047 CanvasManagerService.ctorParameters = function () { return []; };
1048 return CanvasManagerService;
1049}());
1050
1051/**
1052 * @fileoverview added by tsickle
1053 * @suppress {checkTypes} checked by tsc
1054 */
1055var /** @type {?} */ Black = '#000000';
1056var /** @type {?} */ Transparent = 'transparent';
1057var MobileSketchToolComponent = /** @class */ (function () {
1058 function MobileSketchToolComponent(actionSheetCtrl, canvasManagerService, translate) {
1059 this.actionSheetCtrl = actionSheetCtrl;
1060 this.canvasManagerService = canvasManagerService;
1061 this.translate = translate;
1062 this.canvas = new EventEmitter();
1063 this.strokeColor = Black;
1064 this.fillColor = Transparent;
1065 this.isCropping = false;
1066 this.isLoaded = false;
1067 this.isUndoAvailable = false;
1068 this.isSelectingColor = false;
1069 }
1070 /**
1071 * @return {?}
1072 */
1073 MobileSketchToolComponent.prototype.ngOnInit = /**
1074 * @return {?}
1075 */
1076 function () {
1077 if (this.imageData) {
1078 this.canvasManagerService.emptyCanvas();
1079 if (this.loadedJson == null || this.loadedJson.length < 10) {
1080 this.canvasManagerService.setBackgroundFromURL(this.imageData);
1081 }
1082 else {
1083 this.previousJson = JSON.parse(this.loadedJson);
1084 this.currentJson = this.previousJson;
1085 this.canvasManagerService
1086 .loadfromJson(JSON.parse(this.loadedJson));
1087 }
1088 this.isLoaded = true;
1089 this.previousImageData = this.imageData;
1090 }
1091 this.emitCanvas();
1092 };
1093 /**
1094 * @return {?}
1095 */
1096 MobileSketchToolComponent.prototype.ngOnChanges = /**
1097 * @return {?}
1098 */
1099 function () {
1100 if (this.isLoaded) {
1101 if (this.loadedJson === null || this.loadedJson.length < 10 || this.imageData !== this.previousImageData) {
1102 this.canvasManagerService.emptyCanvas();
1103 this.canvasManagerService.setBackgroundFromURL(this.imageData);
1104 this.previousImageData = this.imageData;
1105 this.currentJson = null;
1106 }
1107 else if (this.loadedJson !== JSON.stringify(this.currentJson)) {
1108 this.previousJson = JSON.parse(this.loadedJson);
1109 this.currentJson = this.previousJson;
1110 this.canvasManagerService
1111 .loadfromJson(JSON.parse(this.loadedJson));
1112 }
1113 }
1114 this.emitCanvas();
1115 };
1116 /**
1117 * @return {?}
1118 */
1119 MobileSketchToolComponent.prototype.ngAfterViewInit = /**
1120 * @return {?}
1121 */
1122 function () {
1123 var _this = this;
1124 this.gesture = new Gesture(this.element.nativeElement);
1125 this.gesture.listen();
1126 this.gesture.on('pinch', function ($event) { return _this.pinch($event); });
1127 };
1128 /**
1129 * @return {?}
1130 */
1131 MobileSketchToolComponent.prototype.ngOnDestroy = /**
1132 * @return {?}
1133 */
1134 function () {
1135 this.gesture.destroy();
1136 };
1137 /**
1138 * @param {?} event
1139 * @return {?}
1140 */
1141 MobileSketchToolComponent.prototype.pinchEvent = /**
1142 * @param {?} event
1143 * @return {?}
1144 */
1145 function (event) {
1146 this.canvasManagerService.emptyCanvas();
1147 };
1148 Object.defineProperty(MobileSketchToolComponent.prototype, "hasPictograms", {
1149 get: /**
1150 * @return {?}
1151 */
1152 function () {
1153 return !(!this.icons);
1154 },
1155 enumerable: true,
1156 configurable: true
1157 });
1158 /**
1159 * @return {?}
1160 */
1161 MobileSketchToolComponent.prototype.addText = /**
1162 * @return {?}
1163 */
1164 function () {
1165 this.canvasManagerService.addText(this.strokeColor, 'text ');
1166 this.emitCanvas();
1167 };
1168 /**
1169 * @param {?} shape
1170 * @return {?}
1171 */
1172 MobileSketchToolComponent.prototype.addShape = /**
1173 * @param {?} shape
1174 * @return {?}
1175 */
1176 function (shape) {
1177 this.canvasManagerService.addGeometricShape(this.strokeColor, this.fillColor, AvailableGeometricShape[shape]);
1178 this.emitCanvas();
1179 };
1180 /**
1181 * @param {?} source
1182 * @return {?}
1183 */
1184 MobileSketchToolComponent.prototype.addImage = /**
1185 * @param {?} source
1186 * @return {?}
1187 */
1188 function (source) {
1189 this.canvasManagerService.addImage(this.iconsPath + source);
1190 this.emitCanvas();
1191 };
1192 /**
1193 * @return {?}
1194 */
1195 MobileSketchToolComponent.prototype.changeStrokeColor = /**
1196 * @return {?}
1197 */
1198 function () {
1199 this.canvasManagerService.changeSelectedObjectsStrokeColor(this.strokeColor);
1200 this.canvasManagerService.setFreeDrawingBrushColor(this.strokeColor);
1201 this.emitCanvas();
1202 };
1203 /**
1204 * @return {?}
1205 */
1206 MobileSketchToolComponent.prototype.bringFoward = /**
1207 * @return {?}
1208 */
1209 function () {
1210 this.canvasManagerService.bringSelectedObjectsToFront();
1211 this.emitCanvas();
1212 };
1213 /**
1214 * @return {?}
1215 */
1216 MobileSketchToolComponent.prototype.sendToBack = /**
1217 * @return {?}
1218 */
1219 function () {
1220 this.canvasManagerService.sendSelectedObjectsToBack();
1221 this.emitCanvas();
1222 };
1223 /**
1224 * @return {?}
1225 */
1226 MobileSketchToolComponent.prototype.crop = /**
1227 * @return {?}
1228 */
1229 function () {
1230 this.isCropping = true;
1231 this.canvasManagerService.disableSelection();
1232 this.canvasManagerService.addSelectionRectangle();
1233 this.isUndoAvailable = true;
1234 this.previousJson = this.canvasManagerService.jsonFromCanvas();
1235 this.emitCanvas();
1236 };
1237 /**
1238 * @return {?}
1239 */
1240 MobileSketchToolComponent.prototype.deleteSelection = /**
1241 * @return {?}
1242 */
1243 function () {
1244 this.canvasManagerService.deleteSelectedObjects();
1245 this.emitCanvas();
1246 };
1247 /**
1248 * @param {?} event
1249 * @return {?}
1250 */
1251 MobileSketchToolComponent.prototype.mouseUp = /**
1252 * @param {?} event
1253 * @return {?}
1254 */
1255 function (event) {
1256 if (this.isCropping) {
1257 this.isCropping = false;
1258 this.canvasManagerService.cropImage();
1259 this.isUndoAvailable = true;
1260 this.emitCanvas();
1261 }
1262 };
1263 /**
1264 * @param {?} event
1265 * @return {?}
1266 */
1267 MobileSketchToolComponent.prototype.mouseMove = /**
1268 * @param {?} event
1269 * @return {?}
1270 */
1271 function (event) {
1272 if (this.isCropping) {
1273 this.canvasManagerService.ajustCropRectangle(event);
1274 }
1275 else if (event.touches.length === 3) {
1276 this.canvasManagerService.panCanvas(event);
1277 }
1278 };
1279 /**
1280 * @param {?} event
1281 * @return {?}
1282 */
1283 MobileSketchToolComponent.prototype.mouseDown = /**
1284 * @param {?} event
1285 * @return {?}
1286 */
1287 function (event) {
1288 if (this.isCropping) {
1289 this.canvasManagerService.startSelectingCropRectangle(event);
1290 }
1291 else if (event.touches.length === 3) {
1292 this.canvasManagerService.setLastPanPosition(event);
1293 }
1294 };
1295 /**
1296 * @param {?} event
1297 * @return {?}
1298 */
1299 MobileSketchToolComponent.prototype.pinch = /**
1300 * @param {?} event
1301 * @return {?}
1302 */
1303 function (event) {
1304 event.preventDefault();
1305 this.canvasManagerService.zoom(event);
1306 };
1307 /**
1308 * @return {?}
1309 */
1310 MobileSketchToolComponent.prototype.group = /**
1311 * @return {?}
1312 */
1313 function () {
1314 this.canvasManagerService.groupSelectedObjects();
1315 this.emitCanvas();
1316 };
1317 /**
1318 * @return {?}
1319 */
1320 MobileSketchToolComponent.prototype.undo = /**
1321 * @return {?}
1322 */
1323 function () {
1324 this.canvasManagerService.loadfromJson(this.previousJson);
1325 this.isUndoAvailable = false;
1326 this.emitCanvas();
1327 };
1328 /**
1329 * @return {?}
1330 */
1331 MobileSketchToolComponent.prototype.onColorClicked = /**
1332 * @return {?}
1333 */
1334 function () {
1335 this.isSelectingColor = true;
1336 };
1337 /**
1338 * @param {?} color
1339 * @return {?}
1340 */
1341 MobileSketchToolComponent.prototype.setColor = /**
1342 * @param {?} color
1343 * @return {?}
1344 */
1345 function (color) {
1346 this.strokeColor = color;
1347 this.changeStrokeColor();
1348 this.isSelectingColor = false;
1349 this.emitCanvas();
1350 };
1351 /**
1352 * @return {?}
1353 */
1354 MobileSketchToolComponent.prototype.draw = /**
1355 * @return {?}
1356 */
1357 function () {
1358 this.isDrawing = !this.isDrawing;
1359 this.canvasManagerService.toggleFreeDrawing();
1360 this.canvasManagerService.setFreeDrawingBrushColor(this.strokeColor);
1361 };
1362 /**
1363 * @return {?}
1364 */
1365 MobileSketchToolComponent.prototype.disableDrawing = /**
1366 * @return {?}
1367 */
1368 function () {
1369 if (this.isDrawing) {
1370 this.isDrawing = false;
1371 this.canvasManagerService.toggleFreeDrawing();
1372 }
1373 };
1374 /**
1375 * @return {?}
1376 */
1377 MobileSketchToolComponent.prototype.translateShapeButtonsText = /**
1378 * @return {?}
1379 */
1380 function () {
1381 var /** @type {?} */ translationArray = [];
1382 translationArray.push(this.translate.instant('rectangle'));
1383 translationArray.push(this.translate.instant('triangle'));
1384 translationArray.push(this.translate.instant('circle'));
1385 translationArray.push(this.translate.instant('line'));
1386 translationArray.push(this.translate.instant('cross'));
1387 translationArray.push(this.translate.instant('text'));
1388 return translationArray;
1389 };
1390 /**
1391 * @return {?}
1392 */
1393 MobileSketchToolComponent.prototype.presentShapeActionSheet = /**
1394 * @return {?}
1395 */
1396 function () {
1397 var _this = this;
1398 this.disableDrawing();
1399 var /** @type {?} */ titleText = this.translate.instant('addGeometricShape');
1400 var /** @type {?} */ buttonsText = this.translateShapeButtonsText();
1401 var /** @type {?} */ i = 0;
1402 var /** @type {?} */ actionSheet = this.actionSheetCtrl.create({
1403 title: titleText,
1404 buttons: [
1405 {
1406 text: '\uf0c8 ' + buttonsText[i++],
1407 handler: function () {
1408 _this.canvasManagerService.addGeometricShape(_this.strokeColor, _this.fillColor, AvailableGeometricShape.Rectangle);
1409 }
1410 },
1411 {
1412 text: '\uf0d8 ' + buttonsText[i++],
1413 handler: function () {
1414 _this.canvasManagerService.addGeometricShape(_this.strokeColor, _this.fillColor, AvailableGeometricShape.Triangle);
1415 }
1416 },
1417 {
1418 text: '\uf111 ' + buttonsText[i++],
1419 handler: function () {
1420 _this.canvasManagerService.addGeometricShape(_this.strokeColor, _this.fillColor, AvailableGeometricShape.Circle);
1421 }
1422 },
1423 {
1424 text: '\uf068 ' + buttonsText[i++],
1425 handler: function () {
1426 _this.canvasManagerService.addGeometricShape(_this.strokeColor, _this.fillColor, AvailableGeometricShape.Line);
1427 }
1428 },
1429 {
1430 text: '\uf067 ' + buttonsText[i++],
1431 handler: function () {
1432 _this.canvasManagerService.addGeometricShape(_this.strokeColor, _this.fillColor, AvailableGeometricShape.Cross);
1433 }
1434 },
1435 {
1436 text: '\uf031 ' + buttonsText[i++],
1437 handler: function () {
1438 _this.canvasManagerService.addText(_this.strokeColor, '');
1439 }
1440 }
1441 ]
1442 });
1443 actionSheet.present();
1444 };
1445 /**
1446 * @return {?}
1447 */
1448 MobileSketchToolComponent.prototype.translateEditButtonsText = /**
1449 * @return {?}
1450 */
1451 function () {
1452 var /** @type {?} */ translationArray = [];
1453 translationArray.push(this.translate.instant('crop'));
1454 translationArray.push(this.translate.instant('group'));
1455 translationArray.push(this.translate.instant('bringToFront'));
1456 translationArray.push(this.translate.instant('sendToBack'));
1457 translationArray.push(this.translate.instant('delete'));
1458 return translationArray;
1459 };
1460 /**
1461 * @return {?}
1462 */
1463 MobileSketchToolComponent.prototype.presentEditActionSheet = /**
1464 * @return {?}
1465 */
1466 function () {
1467 var _this = this;
1468 this.disableDrawing();
1469 var /** @type {?} */ titleText = this.translate.instant('edition');
1470 var /** @type {?} */ buttonsText = this.translateEditButtonsText();
1471 var /** @type {?} */ i = 0;
1472 var /** @type {?} */ actionSheet = this.actionSheetCtrl.create({
1473 title: titleText,
1474 buttons: [
1475 {
1476 text: '\uf125 ' + buttonsText[i++],
1477 handler: function () {
1478 _this.crop();
1479 }
1480 },
1481 {
1482 text: '\uf247 ' + buttonsText[i++],
1483 handler: function () {
1484 _this.group();
1485 }
1486 },
1487 {
1488 text: '\uf0de ' + buttonsText[i++],
1489 handler: function () {
1490 _this.bringFoward();
1491 }
1492 },
1493 {
1494 text: '\uf0dd ' + buttonsText[i++],
1495 handler: function () {
1496 _this.sendToBack();
1497 }
1498 },
1499 {
1500 text: '\uf1f8 ' + buttonsText[i++],
1501 handler: function () {
1502 _this.deleteSelection();
1503 }
1504 }
1505 ]
1506 });
1507 actionSheet.present();
1508 };
1509 /**
1510 * @return {?}
1511 */
1512 MobileSketchToolComponent.prototype.presentPictogramsActionSheet = /**
1513 * @return {?}
1514 */
1515 function () {
1516 var _this = this;
1517 this.disableDrawing();
1518 var /** @type {?} */ buttons = [];
1519 var /** @type {?} */ actionSheetStyles = [];
1520 var /** @type {?} */ images = this.icons;
1521 var _loop_1 = function (i) {
1522 var /** @type {?} */ style = document.createElement('style');
1523 style.type = 'text/css';
1524 style.innerHTML =
1525 '.customCSSClass' +
1526 i +
1527 '{background: url(' +
1528 "'" +
1529 this_1.iconsPath +
1530 images[i] +
1531 "'" +
1532 ') no-repeat !important;padding-left:50px !important;height:80px; background-position: left center !important;}';
1533 document.getElementsByTagName('head')[0].appendChild(style);
1534 actionSheetStyles.push(style);
1535 buttons.push({
1536 role: 'destructive',
1537 text: images[i],
1538 cssClass: 'customCSSClass' + i,
1539 handler: function () {
1540 _this.addImage(images[i]);
1541 }
1542 });
1543 };
1544 var this_1 = this;
1545 for (var /** @type {?} */ i = 0; i < images.length; i++) {
1546 _loop_1(i);
1547 }
1548 var /** @type {?} */ titleText = this.translate.instant('addPictogram');
1549 var /** @type {?} */ actionSheet = this.actionSheetCtrl.create({
1550 title: titleText,
1551 buttons: buttons
1552 });
1553 actionSheet.onDidDismiss(function () {
1554 for (var /** @type {?} */ i = 0; i < actionSheetStyles.length; i++) {
1555 if (actionSheetStyles[i].parentNode != null) {
1556 actionSheetStyles[i].parentNode.removeChild(actionSheetStyles[i]);
1557 }
1558 }
1559 });
1560 actionSheet.present();
1561 };
1562 /**
1563 * @return {?}
1564 */
1565 MobileSketchToolComponent.prototype.emitCanvas = /**
1566 * @return {?}
1567 */
1568 function () {
1569 this.canvas.emit(this.canvasManagerService.canvas);
1570 };
1571 MobileSketchToolComponent.decorators = [
1572 { type: Component, args: [{
1573 selector: 'lib-mobile-sketch-tool',
1574 template: "<ion-content>\n <div\n class=\"div-canvas-container\"\n (touchstart)=\"mouseDown($event)\"\n (touchmove)=\"mouseMove($event)\"\n (touchend)=\"mouseUp($event)\"\n #pinchElement\n >\n <canvas id=\"canvas\"></canvas>\n\n <div\n class=\"color-picker\"\n *ngIf=\"isSelectingColor\"\n >\n <ion-grid fixed>\n <ion-row>\n <ion-col\n style=\"background:#660000\"\n (tap)=\"setColor('#660000')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#663300\"\n (tap)=\"setColor('#663300')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#666600\"\n (tap)=\"setColor('#666600')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#006600\"\n (tap)=\"setColor('#006600')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#000066\"\n (tap)=\"setColor('#000066')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#660066\"\n (tap)=\"setColor('#660066')\"\n >\u00A0\n </ion-col>\n\n </ion-row>\n <ion-row>\n <ion-col\n style=\"background:#CC0000\"\n (tap)=\"setColor('#CC0000')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#CC6600\"\n (tap)=\"setColor('#CC6600')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#CCCC00\"\n (tap)=\"setColor('#CCCC00')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#00CC00\"\n (tap)=\"setColor('#00CC00')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#0000CC\"\n (tap)=\"setColor('#0000CC')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#CC00CC\"\n (tap)=\"setColor('#CC00CC')\"\n >\u00A0\n </ion-col>\n\n </ion-row>\n <ion-row>\n <ion-col\n style=\"background:#FF0000\"\n (tap)=\"setColor('#FF0000')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#FF8000\"\n (tap)=\"setColor('#FF8000')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#FFFF00\"\n (tap)=\"setColor('#FFFF00')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#00FF00\"\n (tap)=\"setColor('#00FF00')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#0000FF\"\n (tap)=\"setColor('#0000FF')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#FF00FF\"\n (tap)=\"setColor('#FF00FF')\"\n >\u00A0\n </ion-col>\n\n </ion-row>\n <ion-row>\n <ion-col\n style=\"background:#FF6666\"\n (tap)=\"setColor('#FF6666')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#FFB266\"\n (tap)=\"setColor('#FFB266')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#FFFF66\"\n (tap)=\"setColor('#FFFF66')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#66FF66\"\n (tap)=\"setColor('#66FF66')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#6666FF\"\n (tap)=\"setColor('#6666FF')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#FF66FF\"\n (tap)=\"setColor('#FF66FF')\"\n >\u00A0\n </ion-col>\n\n </ion-row>\n <ion-row>\n <ion-col\n style=\"background:#FF9999\"\n (tap)=\"setColor('#FF9999')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#FFCC99\"\n (tap)=\"setColor('#FFCC99')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#FFFF99\"\n (tap)=\"setColor('#FFFF99')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#99FF99\"\n (tap)=\"setColor('#99FF99')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#9999FF\"\n (tap)=\"setColor('#9999FF')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#FF99FF\"\n (tap)=\"setColor('#FF99FF')\"\n >\u00A0\n </ion-col>\n\n </ion-row>\n <ion-row>\n <ion-col\n style=\"background:#FFFFFF\"\n (tap)=\"setColor('#FFFFFF')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#C0C0C0\"\n (tap)=\"setColor('#C0C0C0')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#808080\"\n (tap)=\"setColor('#808080')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#606060\"\n (tap)=\"setColor('#606060')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#303030\"\n (tap)=\"setColor('#606060')\"\n >\u00A0\n </ion-col>\n <ion-col\n style=\"background:#000000\"\n (tap)=\"setColor('#000000')\"\n >\u00A0\n </ion-col>\n </ion-row>\n </ion-grid>\n </div>\n </div>\n</ion-content>\n\n<ion-footer>\n <ion-toolbar>\n <div class=\"div-edit-toolbar\">\n <button\n class=\"button-edit-toolbar\"\n ion-button\n large\n [clear]=\"true\"\n (click)=\"presentShapeActionSheet()\"\n >\n <i\n class=\"fas fa-shapes\"\n id=\"icon\"\n ></i>\n </button>\n\n <button\n class=\"button-edit-toolbar\"\n ion-button\n large\n [clear]=\"true\"\n (click)=\"presentPictogramsActionSheet()\"\n *ngIf=\"hasPictograms\"\n >\n <i\n class=\"fas fa-images\"\n id=\"icon\"\n ></i>\n </button>\n\n <button\n class=\"button-edit-toolbar\"\n ion-button\n large\n [clear]=\"true\"\n (click)=\"presentEditActionSheet()\"\n >\n <i\n class=\"fas fa-edit\"\n id=\"icon\"\n ></i>\n </button>\n\n <button\n class=\"button-edit-toolbar\"\n ion-button\n large\n [clear]=\"true\"\n (click)=\"draw()\"\n >\n <i\n class=\"fas fa-pencil-alt\"\n id=\"icon\"\n ></i>\n </button>\n\n <button\n class=\"button-edit-toolbar\"\n ion-button\n large\n [clear]=\"true\"\n (click)=\"onColorClicked()\"\n >\n <i\n class=\"fas fa-palette\"\n id=\"icon\"\n ></i>\n </button>\n\n <button\n class=\"button-edit-toolbar\"\n ion-button\n large\n [clear]=\"true\"\n (click)=\"undo()\"\n *ngIf=\"isUndoAvailable\"\n >\n <i\n class=\"fas fa-undo\"\n id=\"icon\"\n ></i>\n </button>\n\n </div>\n </ion-toolbar>\n</ion-footer>\n",
1575 styles: [".div-canvas-container{text-align:center;height:100%;width:100%;-o-object-fit:contain;object-fit:contain}.scroll-content{padding:0!important;overflow-y:hidden}.div-edit-toolbar{text-align:center}.button-edit-toolbar{padding:4%!important;margin:0!important}.action-sheet-button{font-family:FontAwesome,Arial}.color-picker{position:absolute;width:100%;height:auto;bottom:0;left:0}#icon{color:#b32017}"],
1576 providers: [CanvasManagerService]
1577 },] },
1578 ];
1579 /** @nocollapse */
1580 MobileSketchToolComponent.ctorParameters = function () { return [
1581 { type: ActionSheetController, },
1582 { type: CanvasManagerService, },
1583 { type: TranslateService, },
1584 ]; };
1585 MobileSketchToolComponent.propDecorators = {
1586 "element": [{ type: ViewChild, args: ['pinchElement',] },],
1587 "imageData": [{ type: Input },],
1588 "loadedJson": [{ type: Input },],
1589 "iconsPath": [{ type: Input },],
1590 "icons": [{ type: Input },],
1591 "canvas": [{ type: Output },],
1592 };
1593 return MobileSketchToolComponent;
1594}());
1595
1596/**
1597 * @fileoverview added by tsickle
1598 * @suppress {checkTypes} checked by tsc
1599 */
1600var SketchToolModule = /** @class */ (function () {
1601 function SketchToolModule() {
1602 }
1603 SketchToolModule.decorators = [
1604 { type: NgModule, args: [{
1605 imports: [CommonModule, IonicModule],
1606 declarations: [
1607 MobileSketchToolComponent,
1608 ],
1609 providers: [
1610 CanvasManagerService,
1611 ],
1612 exports: [MobileSketchToolComponent]
1613 },] },
1614 ];
1615 return SketchToolModule;
1616}());
1617
1618/**
1619 * @fileoverview added by tsickle
1620 * @suppress {checkTypes} checked by tsc
1621 */
1622
1623/**
1624 * @fileoverview added by tsickle
1625 * @suppress {checkTypes} checked by tsc
1626 */
1627
1628export { MobileSketchToolComponent, CanvasManagerService, SketchToolModule };
1629
1630//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"lib-sketch-tool.js.map","sources":["ng://lib-sketch-tool/app/lib-sketch-tool/constants/shape-data.ts","ng://lib-sketch-tool/app/lib-sketch-tool/services/canvas-manager.service.ts","ng://lib-sketch-tool/app/lib-sketch-tool/mobile-component/mobile-sketch-tool.component.ts","ng://lib-sketch-tool/app/lib-sketch-tool/sketch-tool.module.ts"],"sourcesContent":["export const SHAPE_DATA = {\n  width: 200,\n  height: 200,\n  left: 50,\n  top: 50,\n  radius: 100,\n  stroke: 10,\n  freeDrawingBrushWidth: 10,\n  cornerSize: 20\n};\n","import { Injectable } from '@angular/core';\nimport { fabric } from 'fabric';\n\nimport { AvailableGeometricShape } from './../constants/available-geometric-shapes';\nimport { SHAPE_DATA } from './../constants/shape-data';\n\ninterface ScaleData {\n  scaleFactor: number;\n  left: number;\n  top: number;\n}\n\ninterface Position {\n  x: number;\n  y: number;\n}\n\n@Injectable()\nexport class CanvasManagerService {\n  public canvas;\n\n  private cropRectangle: fabric.Rect;\n  private mousePosition: Position;\n  private cropStartingPosition: Position;\n  private lastPanPosition: fabric.Point;\n\n  constructor() {\n    this.emptyCanvas();\n    this.mousePosition = {x: 0, y: 0};\n    this.cropStartingPosition = {x: 0, y: 0};\n    this.canvas.freeDrawingBrush.width = SHAPE_DATA.freeDrawingBrushWidth;\n  }\n\n  get backgroundImage() {\n    return this.canvas;\n  }\n\n  get canvasObjects() {\n    return this.canvas.getObjects();\n  }\n\n  get canvasBackgroundImage() {\n    return this.canvas.backgroundImage;\n  }\n\n  get activeObject() {\n    return this.canvas.getActiveObject();\n  }\n\n  get activeGroup() {\n    return this.canvas.getActiveObjects();\n  }\n\n  public emptyCanvas(): void {\n    if (this.canvas) {\n      this.canvas.dispose();\n    }\n    this.canvas = new fabric.Canvas('canvas');\n    this.canvas.clear();\n    this.canvas.remove(this.canvas.getObjects());\n  }\n\n  public loadNewImage(backgroundImageURL?: string): void {\n    this.emptyCanvas();\n    if (backgroundImageURL) {\n      this.setBackgroundFromURL(backgroundImageURL);\n    }\n  }\n\n  public renderCanvas(): void {\n    this.markSelectedObjectsDirty();\n    this.canvas.renderAll();\n  }\n\n  public addGeometricShape(strokeColor: string, fillColor: string, shape: AvailableGeometricShape): void {\n    switch (shape) {\n      case AvailableGeometricShape.Rectangle:\n        this.addRectangle(strokeColor, fillColor);\n        break;\n      case AvailableGeometricShape.Circle:\n        this.addCircle(strokeColor, fillColor);\n        break;\n      case AvailableGeometricShape.Triangle:\n        this.addTriangle(strokeColor, fillColor);\n        break;\n      case AvailableGeometricShape.Line:\n        this.addHorizontalLine(strokeColor, fillColor);\n        break;\n      case AvailableGeometricShape.Cross:\n        this.addCross(strokeColor, fillColor);\n        break;\n    }\n  }\n\n  private addRectangle(strokeColor: string, fillColor: string): void {\n    this.canvas.add(\n      new fabric.Rect({\n        width: SHAPE_DATA.width,\n        height: SHAPE_DATA.height,\n        left: SHAPE_DATA.left,\n        top: SHAPE_DATA.top,\n        fill: fillColor,\n        stroke: strokeColor,\n        strokeWidth: SHAPE_DATA.stroke,\n        cornerSize: SHAPE_DATA.cornerSize\n      })\n    );\n  }\n\n  private addCircle(strokeColor: string, fillColor: string): void {\n    this.canvas.add(\n      new fabric.Circle({\n        left: SHAPE_DATA.left,\n        top: SHAPE_DATA.top,\n        radius: SHAPE_DATA.radius,\n        stroke: strokeColor,\n        strokeWidth: SHAPE_DATA.stroke,\n        fill: fillColor,\n        cornerSize: SHAPE_DATA.cornerSize\n      })\n    );\n  }\n\n  private addTriangle(strokeColor: string, fillColor: string): void {\n    this.canvas.add(\n      new fabric.Triangle({\n        width: SHAPE_DATA.width,\n        height: SHAPE_DATA.height,\n        left: SHAPE_DATA.left,\n        top: SHAPE_DATA.top,\n        fill: fillColor,\n        stroke: strokeColor,\n        strokeWidth: SHAPE_DATA.stroke,\n        cornerSize: SHAPE_DATA.cornerSize\n      })\n    );\n  }\n\n  private addHorizontalLine(strokeColor: string, fillColor: string): void {\n    this.canvas.add(this.createHorizontalLine(strokeColor));\n  }\n\n  private createHorizontalLine(strokeColor: string): fabric.Line {\n    const line = new fabric.Line([100, 150, 200, 150], {\n      left: 50,\n      top: 100,\n      stroke: strokeColor,\n      strokeWidth: 5,\n      cornerSize: SHAPE_DATA.cornerSize\n    });\n\n    line.setControlsVisibility({\n      bl: false,\n      br: false,\n      tl: false,\n      tr: false,\n      mt: false,\n      mb: false\n    });\n\n    return line;\n  }\n\n  private createVerticalLine(strokeColor: string): fabric.Line {\n    const line = new fabric.Line([150, 100, 150, 200], {\n      left: 100,\n      top: 50,\n      stroke: strokeColor,\n      strokeWidth: 5,\n      cornerSize: SHAPE_DATA.cornerSize\n    });\n\n    line.setControlsVisibility({\n      bl: false,\n      br: false,\n      tl: false,\n      tr: false,\n      ml: false,\n      mr: false\n    });\n\n    return line;\n  }\n\n  private addCross(strokeColor: string, fillColor: string): void {\n    const horizontalLine = this.createHorizontalLine(strokeColor);\n    const verticalLine = this.createVerticalLine(strokeColor);\n    this.canvas.add(horizontalLine);\n    this.canvas.add(verticalLine);\n  }\n\n  public toggleFreeDrawing(): void {\n    this.canvas.isDrawingMode = !this.canvas.isDrawingMode;\n  }\n\n  public setFreeDrawingBrushColor(color: string): void {\n    this.canvas.freeDrawingBrush.color = color;\n  }\n\n  set freeDrawingBrushWidthFromZoom(zoom) {\n    this.canvas.freeDrawingBrush.width = SHAPE_DATA.freeDrawingBrushWidth * (1 / zoom);\n  }\n\n  public addText(color: string, inputText: string): void {\n    const text = new fabric.IText('text', {\n      fontFamily: 'arial black',\n      fontStyle: 'bold',\n      left: SHAPE_DATA.left,\n      top: SHAPE_DATA.top,\n      cornerSize: SHAPE_DATA.cornerSize\n    });\n\n    text.setColor(color);\n\n    this.canvas.add(text);\n  }\n\n  public addImage(imageURL: string): Promise<void> {\n    return new Promise(\n      (resolve, reject): void => {\n        const canvas = this.canvas;\n\n        const image = new Image();\n        image.onload = function(img) {\n          const fabricImage = new fabric.Image(image, {\n            angle: 0,\n            width: image.width,\n            height: image.height,\n            left: SHAPE_DATA.left,\n            top: SHAPE_DATA.top,\n            scaleX: 1,\n            scaleY: 1,\n            cornerSize: SHAPE_DATA.cornerSize\n          });\n          canvas.add(fabricImage);\n          resolve();\n        };\n        image.src = imageURL;\n      }\n    );\n  }\n\n  public setBackgroundFromURL(backgroundImageURL: string): Promise<void> {\n    const canvas = this.canvas;\n    const resize = this.resizeCanvasAndComputeScaleFactor;\n\n    return new Promise(\n      (resolve, reject): void => {\n        if (backgroundImageURL == null) {\n          return reject();\n        }\n        const image = new Image();\n        image.onload = function() {\n          const f_img = new fabric.Image(image, {});\n\n          const scaleData = resize(f_img, canvas);\n\n          canvas.setBackgroundImage(f_img, canvas.renderAll.bind(canvas), {\n            scaleX: scaleData.scaleFactor,\n            scaleY: scaleData.scaleFactor\n          });\n\n          canvas.renderAll();\n          resolve();\n        };\n        image.src = backgroundImageURL;\n      }\n    );\n  }\n\n  private resizeCanvasAndComputeScaleFactor(f_img: fabric.Image, canvas: fabric.Canvas): ScaleData {\n    const container = document.getElementsByClassName(\n      'div-canvas-container'\n    )[0];\n\n    canvas.setWidth(container.clientWidth);\n    canvas.setHeight(container.clientHeight);\n\n    const canvasWidth = canvas.getWidth();\n    const canvasHeight = canvas.getHeight();\n\n    const canvasAspect = canvasWidth / canvasHeight;\n    const imgAspect = f_img.width / f_img.height;\n    let left, top, scaleFactor;\n\n    if (canvasAspect <= imgAspect) {\n      scaleFactor = canvasWidth / f_img.width;\n      left = 0;\n      top = -(f_img.height * scaleFactor - canvasHeight) / 2;\n    } else {\n      scaleFactor = canvasHeight / f_img.height;\n      top = 0;\n      left = -(f_img.width * scaleFactor - canvasWidth) / 2;\n    }\n    return { scaleFactor: scaleFactor, left: left, top: top };\n  }\n\n  public onOrientationChange() {\n    this.mousePosition = {x: this.canvas.getWidth, y: this.canvas.getHeight };\n    this.cropImage();\n  }\n\n  public changeSelectedObjectsFillColor(color: string): void {\n    const activeObjects = this.canvas.getActiveObjects();\n\n    if (activeObjects) {\n      for (const object of activeObjects) {\n        object.setColor(color);\n        this.canvas.renderAll();\n      }\n    }\n  }\n\n  public changeSelectedObjectsStrokeColor(color: string): void {\n    const activeObjects = this.canvas.getActiveObjects();\n\n    if (activeObjects) {\n      for (const object of activeObjects) {\n        if (object.type === 'i-text') {\n          object.setColor(color);\n        } else {\n          object.stroke = color;\n          object.set('dirty', true);\n        }\n      }\n      this.canvas.renderAll();\n    }\n  }\n\n  public deleteSelectedObjects(): void {\n    const activeObjects = this.canvas.getActiveObjects();\n\n    if (activeObjects) {\n      for (const object of activeObjects) {\n        this.canvas.remove(object);\n      }\n      this.canvas.discardActiveObject();\n      this.canvas.renderAll();\n    }\n  }\n\n  public bringSelectedObjectsToFront(): void {\n    const activeObjects = this.canvas.getActiveObjects();\n\n    if (activeObjects) {\n      for (const object of activeObjects) {\n        this.canvas.bringToFront(object);\n      }\n    }\n  }\n\n  public sendSelectedObjectsToBack(): void {\n    const activeObjects = this.canvas.getActiveObjects();\n\n    if (activeObjects) {\n      for (const object of activeObjects) {\n        this.canvas.sendToBack(object);\n      }\n    }\n  }\n\n  public jsonFromCanvas(): JSON {\n    return this.canvas.toJSON();\n  }\n\n  public loadfromJson(json: JSON): Promise<void> {\n    const container = document.getElementsByClassName(\n      'div-canvas-container'\n    )[0];\n\n    this.canvas.setWidth(container.clientWidth);\n    this.canvas.setHeight(container.clientHeight);\n\n    return new Promise(\n      (resolve, reject): void => {\n        this.adjustCanvas(json);\n        this.canvas.loadFromJSON(json, this.canvas.renderAll.bind(this.canvas));\n        resolve();\n      }\n    );\n  }\n\n  public adjustCanvas(json: JSON): void {\n    const backgroundImage = json['backgroundImage'];\n\n    const container = document.getElementsByClassName(\n      'div-canvas-container'\n    )[0];\n\n    const width = backgroundImage['width'];\n    const height = backgroundImage['height'];\n\n    const canvasWidth = container.clientWidth;\n    const canvasHeight = container.clientHeight;\n\n    const canvasAspect = canvasWidth / canvasHeight;\n    const imgAspect = width / height;\n    let scaleFactor;\n\n    if (canvasAspect <= imgAspect) {\n      scaleFactor = canvasWidth / width;\n    } else {\n      scaleFactor = canvasHeight / height;\n    }\n\n    const objectScale = scaleFactor / backgroundImage['scaleX'];\n\n    backgroundImage['scaleX'] = scaleFactor;\n    backgroundImage['scaleY'] = scaleFactor;\n\n    this.canvas.setWidth(width * scaleFactor);\n    this.canvas.setHeight(height * scaleFactor);\n\n    const objects = json['objects'];\n\n    for (let i = 0; i < objects.length; i++) {\n      objects[i]['left'] *= objectScale;\n      objects[i]['top'] *= objectScale;\n      objects[i]['scaleX'] *= objectScale;\n      objects[i]['scaleY'] *= objectScale;\n    }\n\n    this.canvas.selectable = true;\n    this.canvas.selection = true;\n\n    this.canvas.renderAll();\n  }\n\n  public exportImageAsDataURL(): string {\n    return this.canvas.toDataURL('image/png');\n  }\n\n  public selectItem(itemNumber: number): void {\n    this.canvas.setActiveObject(this.canvas.item(itemNumber));\n  }\n\n  public getIndexOf(activeObject): number {\n    return this.canvas.getObjects().indexOf(activeObject);\n  }\n\n  private selectLastObject(): void {\n    const itemNumber = this.canvas.getObjects().length - 1;\n    const object = this.canvas.item(itemNumber);\n    this.canvas.setActiveObject(object);\n    object.enterEditing();\n  }\n\n  private markSelectedObjectsDirty(): void {\n    const activeObjects = this.canvas.getActiveObjects();\n\n    if (activeObjects) {\n      for (const object of activeObjects) {\n        object.set('dirty', true);\n      }\n    }\n  }\n\n  public addSelectionRectangle(): void {\n    this.cropRectangle = new fabric.Rect({\n      fill: 'transparent',\n      originX: 'left',\n      originY: 'top',\n      stroke: '#ccc',\n      strokeDashArray: [2, 2],\n      opacity: 1,\n      width: 1,\n      height: 1\n    });\n\n    this.cropRectangle.visible = false;\n    this.canvas.add(this.cropRectangle);\n  }\n\n  public ajustCropRectangleFromMouse(event: MouseEvent): boolean {\n    const x = Math.min(event.layerX, this.mousePosition.x),\n      y = Math.min(event.layerY, this.mousePosition.y),\n      w = Math.abs(event.layerX - this.mousePosition.x),\n      h = Math.abs(event.layerY - this.mousePosition.y);\n\n    if (!w || !h) {\n      return false;\n    }\n\n    this.cropRectangle\n      .set('top', y)\n      .set('left', x)\n      .set('width', w)\n      .set('height', h);\n\n    this.canvas.renderAll();\n\n    return true;\n  }\n\n  public startSelectingCropRectangleFromMouse(event: MouseEvent): void {\n    this.cropStartingPosition = { x: this.canvas.left, y: this.canvas.top };\n\n    this.cropRectangle.left = event.layerX;\n    this.cropRectangle.top = event.layerY;\n    this.cropRectangle.setCoords();\n\n    this.mousePosition = {x: event.layerX, y: event.layerY };\n\n    this.canvas.renderAll();\n    this.cropRectangle.visible = true;\n    this.canvas.bringToFront(this.cropRectangle);\n  }\n\n  public cropImage(): void {\n    const left = this.cropRectangle.left;\n    const top = this.cropRectangle.top;\n\n    const width = this.cropRectangle.width;\n    const height = this.cropRectangle.height;\n\n    const container = document.getElementsByClassName(\n      'div-canvas-container'\n    )[0];\n\n    const canvasWidth = container.clientWidth;\n    const canvasHeight = container.clientHeight;\n\n    const canvasAspect = canvasWidth / canvasHeight;\n    const imgAspect = width / height;\n    let scaleFactor;\n\n    if (canvasAspect <= imgAspect) {\n      scaleFactor = canvasWidth / width;\n    } else {\n      scaleFactor = canvasHeight / height;\n    }\n\n    this.canvas.setWidth(width * scaleFactor);\n    this.canvas.setHeight(height * scaleFactor);\n\n    this.canvas.backgroundImage.scaleX *= scaleFactor;\n    this.canvas.backgroundImage.scaleY *= scaleFactor;\n\n    this.canvas.backgroundImage.left -= left;\n    this.canvas.backgroundImage.left *= scaleFactor;\n    this.canvas.backgroundImage.top -= top - scaleFactor;\n    this.canvas.backgroundImage.top *= scaleFactor;\n\n    this.moveAllObjectsInCanvas(-1 * left, -1 * top, scaleFactor);\n\n    this.canvas.selectable = true;\n    this.canvas.selection = true;\n    this.cropRectangle.visible = false;\n\n    this.canvas.remove(this.cropRectangle);\n\n    this.canvas.renderAll();\n  }\n\n  public ajustCropRectangle(event): boolean {\n    const touch = event.touches[0];\n\n    const rect = event.target.getBoundingClientRect();\n\n    const x = Math.min(touch.clientX - rect.left, this.mousePosition.x),\n      y = Math.min(touch.clientY - rect.top, this.mousePosition.y),\n      w = Math.abs(touch.clientX - rect.left - this.mousePosition.x),\n      h = Math.abs(touch.clientY - rect.top - this.mousePosition.y);\n\n    if (!w || !h) {\n      return false;\n    }\n\n    this.cropRectangle\n      .set('left', x)\n      .set('top', y)\n      .set('width', w)\n      .set('height', h);\n\n    this.canvas.renderAll();\n\n    return true;\n  }\n\n  public startSelectingCropRectangle(event): void {\n    this.cropStartingPosition = { x: this.canvas.left, y: this.canvas.top };\n\n    const touch = event.touches[0];\n    const rect = event.target.getBoundingClientRect();\n\n    this.cropRectangle.left = touch.clientX - rect.left;\n    this.cropRectangle.top = touch.clientY - rect.top;\n    this.cropRectangle.setCoords();\n\n    this.mousePosition = { x: touch.clientX - rect.left, y: touch.clientY - rect.top };\n\n    this.canvas.renderAll();\n    this.cropRectangle.visible = true;\n    this.canvas.bringToFront(this.cropRectangle);\n  }\n\n  public disableSelection() {\n    this.canvas.selection = false;\n  }\n\n  private moveAllObjectsInCanvas(x: number, y: number, scaleFactor: number): void {\n    const objects = this.canvas.getObjects();\n    for (const obj of objects) {\n      obj.left += x;\n      obj.left *= scaleFactor;\n      obj.scaleX *= scaleFactor;\n      obj.top += y;\n      obj.scaleY *= scaleFactor;\n      obj.top *= scaleFactor;\n      obj.setCoords();\n    }\n  }\n\n  public groupSelectedObjects(): void {\n    const activeObjects = this.canvas.getActiveObjects();\n\n    if (activeObjects) {\n      const objects = [];\n\n      for (const object of activeObjects) {\n        objects.push(object);\n      }\n      this.deleteSelectedObjects();\n\n      const group = new fabric.Group(objects);\n      this.canvas.add(group);\n      group.setCoords();\n\n      this.canvas.setActiveObject(group);\n\n      this.canvas.renderAll();\n    }\n  }\n\n  public setLastPanPosition(event) {\n    this.lastPanPosition = new fabric.Point(event.touches[0].clientX, event.touches[0].clientY);\n  }\n\n  public panCanvas(event): void {\n    const delta = new fabric.Point(\n      event.touches[0].clientX - this.lastPanPosition.x,\n      event.touches[0].clientY - this.lastPanPosition.y\n    );\n\n    this.canvas.relativePan(delta);\n    this.preventPanOutsideCanvas();\n\n    this.canvas.renderAll();\n    this.setLastPanPosition(event);\n  }\n\n  private preventPanOutsideCanvas() {\n    const canvasViewPort = this.canvas.viewportTransform;\n\n    const imageHeight = this.canvas.height * canvasViewPort[0];\n    const imageWidth = this.canvas.width * canvasViewPort[0];\n\n    const bottomEndPoint = this.canvas.height * (canvasViewPort[0] - 1);\n    if (canvasViewPort[5] >= 0 || -bottomEndPoint > canvasViewPort[5]) {\n        canvasViewPort[5] = (canvasViewPort[5] >= 0) ? 0 : -bottomEndPoint;\n    }\n\n    const rightEndPoint = this.canvas.width * (canvasViewPort[0] - 1);\n    if (canvasViewPort[4] >= 0 || -rightEndPoint > canvasViewPort[4]) {\n        canvasViewPort[4] = (canvasViewPort[4] >= 0) ? 0 : -rightEndPoint;\n    }\n  }\n\n  public zoom(event): void {\n    const point = new fabric.Point(event.center.x, event.center.y);\n\n    let zoom = this.canvas.getZoom();\n    if (event.additionalEvent === 'pinchout') {\n      zoom *= 1.05;\n    }\n    if (event.additionalEvent === 'pinchin') {\n      zoom /= 1.05;\n    }\n\n    if (zoom < 1) {\n      zoom = 1;\n      this.canvas.zoomToPoint(new fabric.Point(0, 0), zoom);\n      this.canvas.absolutePan(new fabric.Point(0, 0));\n    } else {\n      if (zoom > 10) {\n        zoom = 10;\n      }\n      this.canvas.zoomToPoint(point, zoom);\n    }\n\n    this.freeDrawingBrushWidthFromZoom(zoom);\n    this.canvas.renderAll();\n  }\n}\n","import { Component, Input, Output, OnInit, OnChanges, AfterViewInit, EventEmitter, transition, ElementRef, ViewChild, OnDestroy } from '@angular/core';\nimport { ActionSheetController } from 'ionic-angular';\nimport { Gesture } from 'ionic-angular/gestures/gesture';\nimport { AvailableGeometricShape } from './../constants/available-geometric-shapes';\nimport { CanvasManagerService } from './../services/canvas-manager.service';\nimport { fabric } from 'fabric';\nimport { TranslateService } from \"@ngx-translate/core\";\n\nconst Black = '#000000';\nconst Transparent = 'transparent';\n\n@Component({\n  selector: 'lib-mobile-sketch-tool',\n  template: `<ion-content>\n    <div\n        class=\"div-canvas-container\"\n        (touchstart)=\"mouseDown($event)\"\n        (touchmove)=\"mouseMove($event)\"\n        (touchend)=\"mouseUp($event)\"\n        #pinchElement\n    >\n        <canvas id=\"canvas\"></canvas>\n\n        <div\n            class=\"color-picker\"\n            *ngIf=\"isSelectingColor\"\n        >\n            <ion-grid fixed>\n                <ion-row>\n                    <ion-col\n                        style=\"background:#660000\"\n                        (tap)=\"setColor('#660000')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#663300\"\n                        (tap)=\"setColor('#663300')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#666600\"\n                        (tap)=\"setColor('#666600')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#006600\"\n                        (tap)=\"setColor('#006600')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#000066\"\n                        (tap)=\"setColor('#000066')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#660066\"\n                        (tap)=\"setColor('#660066')\"\n                    >Â \n                    </ion-col>\n\n                </ion-row>\n                <ion-row>\n                    <ion-col\n                        style=\"background:#CC0000\"\n                        (tap)=\"setColor('#CC0000')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#CC6600\"\n                        (tap)=\"setColor('#CC6600')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#CCCC00\"\n                        (tap)=\"setColor('#CCCC00')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#00CC00\"\n                        (tap)=\"setColor('#00CC00')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#0000CC\"\n                        (tap)=\"setColor('#0000CC')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#CC00CC\"\n                        (tap)=\"setColor('#CC00CC')\"\n                    >Â \n                    </ion-col>\n\n                </ion-row>\n                <ion-row>\n                    <ion-col\n                        style=\"background:#FF0000\"\n                        (tap)=\"setColor('#FF0000')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#FF8000\"\n                        (tap)=\"setColor('#FF8000')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#FFFF00\"\n                        (tap)=\"setColor('#FFFF00')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#00FF00\"\n                        (tap)=\"setColor('#00FF00')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#0000FF\"\n                        (tap)=\"setColor('#0000FF')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#FF00FF\"\n                        (tap)=\"setColor('#FF00FF')\"\n                    >Â \n                    </ion-col>\n\n                </ion-row>\n                <ion-row>\n                    <ion-col\n                        style=\"background:#FF6666\"\n                        (tap)=\"setColor('#FF6666')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#FFB266\"\n                        (tap)=\"setColor('#FFB266')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#FFFF66\"\n                        (tap)=\"setColor('#FFFF66')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#66FF66\"\n                        (tap)=\"setColor('#66FF66')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#6666FF\"\n                        (tap)=\"setColor('#6666FF')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#FF66FF\"\n                        (tap)=\"setColor('#FF66FF')\"\n                    >Â \n                    </ion-col>\n\n                </ion-row>\n                <ion-row>\n                    <ion-col\n                        style=\"background:#FF9999\"\n                        (tap)=\"setColor('#FF9999')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#FFCC99\"\n                        (tap)=\"setColor('#FFCC99')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#FFFF99\"\n                        (tap)=\"setColor('#FFFF99')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#99FF99\"\n                        (tap)=\"setColor('#99FF99')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#9999FF\"\n                        (tap)=\"setColor('#9999FF')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#FF99FF\"\n                        (tap)=\"setColor('#FF99FF')\"\n                    >Â \n                    </ion-col>\n\n                </ion-row>\n                <ion-row>\n                    <ion-col\n                        style=\"background:#FFFFFF\"\n                        (tap)=\"setColor('#FFFFFF')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#C0C0C0\"\n                        (tap)=\"setColor('#C0C0C0')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#808080\"\n                        (tap)=\"setColor('#808080')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#606060\"\n                        (tap)=\"setColor('#606060')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#303030\"\n                        (tap)=\"setColor('#606060')\"\n                    >Â \n                    </ion-col>\n                    <ion-col\n                        style=\"background:#000000\"\n                        (tap)=\"setColor('#000000')\"\n                    >Â \n                    </ion-col>\n                </ion-row>\n            </ion-grid>\n        </div>\n    </div>\n</ion-content>\n\n<ion-footer>\n    <ion-toolbar>\n        <div class=\"div-edit-toolbar\">\n            <button\n                class=\"button-edit-toolbar\"\n                ion-button\n                large\n                [clear]=\"true\"\n                (click)=\"presentShapeActionSheet()\"\n            >\n                <i\n                    class=\"fas fa-shapes\"\n                    id=\"icon\"\n                ></i>\n            </button>\n\n            <button\n                class=\"button-edit-toolbar\"\n                ion-button\n                large\n                [clear]=\"true\"\n                (click)=\"presentPictogramsActionSheet()\"\n                *ngIf=\"hasPictograms\"\n            >\n                <i\n                    class=\"fas fa-images\"\n                    id=\"icon\"\n                ></i>\n            </button>\n\n            <button\n                class=\"button-edit-toolbar\"\n                ion-button\n                large\n                [clear]=\"true\"\n                (click)=\"presentEditActionSheet()\"\n            >\n                <i\n                    class=\"fas fa-edit\"\n                    id=\"icon\"\n                ></i>\n            </button>\n\n            <button\n                class=\"button-edit-toolbar\"\n                ion-button\n                large\n                [clear]=\"true\"\n                (click)=\"draw()\"\n            >\n                <i\n                    class=\"fas fa-pencil-alt\"\n                    id=\"icon\"\n                ></i>\n            </button>\n\n            <button\n                class=\"button-edit-toolbar\"\n                ion-button\n                large\n                [clear]=\"true\"\n                (click)=\"onColorClicked()\"\n            >\n                <i\n                    class=\"fas fa-palette\"\n                    id=\"icon\"\n                ></i>\n            </button>\n\n            <button\n                class=\"button-edit-toolbar\"\n                ion-button\n                large\n                [clear]=\"true\"\n                (click)=\"undo()\"\n                *ngIf=\"isUndoAvailable\"\n            >\n                <i\n                    class=\"fas fa-undo\"\n                    id=\"icon\"\n                ></i>\n            </button>\n\n        </div>\n    </ion-toolbar>\n</ion-footer>\n`,\n  styles: [`.div-canvas-container{text-align:center;height:100%;width:100%;-o-object-fit:contain;object-fit:contain}.scroll-content{padding:0!important;overflow-y:hidden}.div-edit-toolbar{text-align:center}.button-edit-toolbar{padding:4%!important;margin:0!important}.action-sheet-button{font-family:FontAwesome,Arial}.color-picker{position:absolute;width:100%;height:auto;bottom:0;left:0}#icon{color:#b32017}`],\n  providers: [CanvasManagerService]\n})\nexport class MobileSketchToolComponent implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n  private gesture: Gesture;\n  @ViewChild('pinchElement') element;\n\n  public fillColor: string;\n  public strokeColor: string;\n  public isCropping: boolean;\n  public isUndoAvailable: boolean;\n  public isSelectingColor: boolean;\n  public isDrawing: boolean;\n\n  @Input() public imageData: string;\n  @Input() public loadedJson: string;\n  @Input() public iconsPath: string;\n  @Input() public icons: [string];\n\n  @Output() public canvas = new EventEmitter<fabric.Canvas>();\n\n  private isLoaded: boolean;\n  private isPanning: boolean;\n  private previousImageData: string;\n  private currentJson: JSON;\n  private previousJson: JSON;\n\n  constructor(\n    public actionSheetCtrl: ActionSheetController,\n    private canvasManagerService: CanvasManagerService,\n    private translate: TranslateService\n  ) {\n    this.strokeColor = Black;\n    this.fillColor = Transparent;\n    this.isCropping = false;\n    this.isLoaded = false;\n    this.isUndoAvailable = false;\n    this.isSelectingColor = false;\n  }\n\n  ngOnInit() {\n    if (this.imageData) {\n      this.canvasManagerService.emptyCanvas();\n      if (this.loadedJson == null || this.loadedJson.length < 10) {\n        this.canvasManagerService.setBackgroundFromURL(this.imageData);\n      } else {\n        this.previousJson = JSON.parse(this.loadedJson);\n        this.currentJson = this.previousJson;\n        this.canvasManagerService\n          .loadfromJson(JSON.parse(this.loadedJson));\n      }\n      this.isLoaded = true;\n      this.previousImageData = this.imageData;\n    }\n    this.emitCanvas();\n  }\n\n  ngOnChanges() {\n    if (this.isLoaded) {\n      if (this.loadedJson === null || this.loadedJson.length < 10 || this.imageData !== this.previousImageData) {\n        this.canvasManagerService.emptyCanvas();\n        this.canvasManagerService.setBackgroundFromURL(this.imageData);\n        this.previousImageData = this.imageData;\n        this.currentJson = null;\n      } else if (this.loadedJson !== JSON.stringify(this.currentJson)) {\n          this.previousJson = JSON.parse(this.loadedJson);\n          this.currentJson = this.previousJson;\n          this.canvasManagerService\n            .loadfromJson(JSON.parse(this.loadedJson));\n      }\n    }\n    this.emitCanvas();\n  }\n\n  ngAfterViewInit() {\n    this.gesture = new Gesture(this.element.nativeElement);\n    this.gesture.listen();\n    this.gesture.on('pinch', $event => this.pinch($event));\n  }\n\n  ngOnDestroy() {\n    this.gesture.destroy();\n}\n\n  private pinchEvent(event) {\n      this.canvasManagerService.emptyCanvas();\n  }\n\n  get hasPictograms(): boolean {\n    return !(!this.icons);\n  }\n\n  public addText() {\n    this.canvasManagerService.addText(this.strokeColor, 'text ');\n    this.emitCanvas();\n  }\n\n  public addShape(shape: string) {\n    this.canvasManagerService.addGeometricShape(\n      this.strokeColor,\n      this.fillColor,\n      AvailableGeometricShape[shape]\n    );\n    this.emitCanvas();\n  }\n\n  public addImage(source: string) {\n    this.canvasManagerService.addImage(this.iconsPath + source);\n    this.emitCanvas();\n  }\n\n  public changeStrokeColor() {\n    this.canvasManagerService.changeSelectedObjectsStrokeColor(\n      this.strokeColor\n    );\n    this.canvasManagerService.setFreeDrawingBrushColor(this.strokeColor);\n    this.emitCanvas();\n  }\n\n  public bringFoward() {\n    this.canvasManagerService.bringSelectedObjectsToFront();\n    this.emitCanvas();\n  }\n\n  public sendToBack() {\n    this.canvasManagerService.sendSelectedObjectsToBack();\n    this.emitCanvas();\n  }\n\n  public crop() {\n    this.isCropping = true;\n    this.canvasManagerService.disableSelection();\n    this.canvasManagerService.addSelectionRectangle();\n    this.isUndoAvailable = true;\n    this.previousJson = this.canvasManagerService.jsonFromCanvas();\n    this.emitCanvas();\n  }\n\n  public deleteSelection() {\n    this.canvasManagerService.deleteSelectedObjects();\n    this.emitCanvas();\n  }\n\n  public mouseUp(event) {\n    if (this.isCropping) {\n      this.isCropping = false;\n      this.canvasManagerService.cropImage();\n      this.isUndoAvailable = true;\n      this.emitCanvas();\n    }\n  }\n\n  public mouseMove(event) {\n    if (this.isCropping) {\n      this.canvasManagerService.ajustCropRectangle(event);\n    } else if (event.touches.length === 3) {\n        this.canvasManagerService.panCanvas(event);\n    }\n  }\n\n  public mouseDown(event) {\n    if (this.isCropping) {\n      this.canvasManagerService.startSelectingCropRectangle(event);\n    } else if (event.touches.length === 3) {\n        this.canvasManagerService.setLastPanPosition(event);\n    }\n  }\n\n  public pinch(event) {\n    event.preventDefault();\n    this.canvasManagerService.zoom(event);\n  }\n\n  public group() {\n    this.canvasManagerService.groupSelectedObjects();\n    this.emitCanvas();\n  }\n\n  public undo() {\n    this.canvasManagerService.loadfromJson(this.previousJson);\n    this.isUndoAvailable = false;\n    this.emitCanvas();\n  }\n\n  public onColorClicked() {\n    this.isSelectingColor = true;\n  }\n\n  public setColor(color: string) {\n    this.strokeColor = color;\n    this.changeStrokeColor();\n    this.isSelectingColor = false;\n    this.emitCanvas();\n  }\n\n  public draw() {\n    this.isDrawing = !this.isDrawing;\n    this.canvasManagerService.toggleFreeDrawing();\n    this.canvasManagerService.setFreeDrawingBrushColor(this.strokeColor);\n  }\n\n  private disableDrawing() {\n    if (this.isDrawing) {\n      this.isDrawing = false;\n      this.canvasManagerService.toggleFreeDrawing();\n    }\n  }\n\n  private translateShapeButtonsText(): Array<String> {\n    const translationArray = [];\n    translationArray.push(this.translate.instant('rectangle'));\n    translationArray.push(this.translate.instant('triangle'));\n    translationArray.push(this.translate.instant('circle'));\n    translationArray.push(this.translate.instant('line'));\n    translationArray.push(this.translate.instant('cross'));\n    translationArray.push(this.translate.instant('text'));\n    return translationArray;\n  }\n\n  public presentShapeActionSheet() {\n    this.disableDrawing();\n\n    const titleText = this.translate.instant('addGeometricShape');\n    const buttonsText = this.translateShapeButtonsText();\n    let i = 0;\n\n    const actionSheet = this.actionSheetCtrl.create({\n      title: titleText,\n      buttons: [\n        {\n          text: '\\uf0c8   ' + buttonsText[i++],\n          handler: () => {\n            this.canvasManagerService.addGeometricShape(\n              this.strokeColor,\n              this.fillColor,\n              AvailableGeometricShape.Rectangle\n            );\n          }\n        },\n        {\n          text: '\\uf0d8   ' + buttonsText[i++],\n          handler: () => {\n            this.canvasManagerService.addGeometricShape(\n              this.strokeColor,\n              this.fillColor,\n              AvailableGeometricShape.Triangle\n            );\n          }\n        },\n        {\n          text: '\\uf111   ' + buttonsText[i++],\n          handler: () => {\n            this.canvasManagerService.addGeometricShape(\n              this.strokeColor,\n              this.fillColor,\n              AvailableGeometricShape.Circle\n            );\n          }\n        },\n        {\n          text: '\\uf068   ' + buttonsText[i++],\n          handler: () => {\n            this.canvasManagerService.addGeometricShape(\n              this.strokeColor,\n              this.fillColor,\n              AvailableGeometricShape.Line\n            );\n          }\n        },\n        {\n          text: '\\uf067   ' + buttonsText[i++],\n          handler: () => {\n            this.canvasManagerService.addGeometricShape(\n              this.strokeColor,\n              this.fillColor,\n              AvailableGeometricShape.Cross\n            );\n          }\n        },\n        {\n          text: '\\uf031   ' + buttonsText[i++],\n          handler: () => {\n            this.canvasManagerService.addText(this.strokeColor, '');\n          }\n        }\n      ]\n    });\n    actionSheet.present();\n  }\n\n  private translateEditButtonsText(): Array<String> {\n    const translationArray = [];\n    translationArray.push(this.translate.instant('crop'));\n    translationArray.push(this.translate.instant('group'));\n    translationArray.push(this.translate.instant('bringToFront'));\n    translationArray.push(this.translate.instant('sendToBack'));\n    translationArray.push(this.translate.instant('delete'));\n    return translationArray;\n  }\n\n  public presentEditActionSheet() {\n    this.disableDrawing();\n\n    const titleText = this.translate.instant('edition');\n\n    const buttonsText = this.translateEditButtonsText();\n    let i = 0;\n\n    const actionSheet = this.actionSheetCtrl.create({\n      title: titleText,\n      buttons: [\n        {\n          text: '\\uf125 ' + buttonsText[i++],\n          handler: () => {\n            this.crop();\n          }\n        },\n        {\n          text: '\\uf247   ' + buttonsText[i++],\n          handler: () => {\n            this.group();\n          }\n        },\n        {\n          text: '\\uf0de   ' + buttonsText[i++],\n          handler: () => {\n            this.bringFoward();\n          }\n        },\n        {\n          text: '\\uf0dd   ' + buttonsText[i++],\n          handler: () => {\n            this.sendToBack();\n          }\n        },\n        {\n          text: '\\uf1f8   ' + buttonsText[i++],\n          handler: () => {\n            this.deleteSelection();\n          }\n        }\n      ]\n    });\n    actionSheet.present();\n  }\n\n  public presentPictogramsActionSheet() {\n    this.disableDrawing();\n\n    const buttons = [];\n    const actionSheetStyles = [];\n    const images = this.icons;\n    for (let i = 0; i < images.length; i++) {\n      const style = document.createElement('style');\n      style.type = 'text/css';\n      style.innerHTML =\n        '.customCSSClass' +\n        i +\n        '{background: url(' +\n        \"'\" +\n        this.iconsPath +\n        images[i] +\n        \"'\" +\n        ') no-repeat !important;padding-left:50px !important;height:80px; background-position: left center !important;}';\n      document.getElementsByTagName('head')[0].appendChild(style);\n      actionSheetStyles.push(style);\n      buttons.push({\n        role: 'destructive',\n        text: images[i],\n        cssClass: 'customCSSClass' + i,\n        handler: () => {\n          this.addImage(images[i]);\n        }\n      });\n    }\n\n    const titleText = this.translate.instant('addPictogram');\n\n    const actionSheet = this.actionSheetCtrl.create({\n      title: titleText,\n      buttons: buttons\n    });\n    actionSheet.onDidDismiss(() => {\n      for (let i = 0; i < actionSheetStyles.length; i++) {\n        if (actionSheetStyles[i].parentNode != null) {\n          actionSheetStyles[i].parentNode.removeChild(actionSheetStyles[i]);\n        }\n      }\n    });\n\n    actionSheet.present();\n  }\n\n  public emitCanvas() {\n    this.canvas.emit(this.canvasManagerService.canvas);\n  }\n}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { IonicModule } from 'ionic-angular';\n\nimport { MobileSketchToolComponent } from './mobile-component/mobile-sketch-tool.component';\nimport { CanvasManagerService } from './services/canvas-manager.service';\n\n@NgModule({\n  imports: [CommonModule, IonicModule],\n  declarations: [\n    MobileSketchToolComponent,\n  ],\n  providers: [\n    CanvasManagerService,\n  ],\n  exports: [MobileSketchToolComponent]\n})\nexport class SketchToolModule {}\n"],"names":["tslib_1.__values"],"mappings":"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"}
\No newline at end of file