@eqproject/eqp-dynamic-module 2.4.3 → 2.4.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (30) hide show
  1. package/esm2020/lib/components/exported/eqp-dynamic-module/eqp-dynamic-module.component.mjs +1 -1
  2. package/esm2020/lib/components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component.mjs +3 -3
  3. package/esm2020/lib/components/private/dynamic-module-field/dynamic-module-field.component.mjs +1 -1
  4. package/esm2020/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.mjs +14 -4
  5. package/esm2020/lib/components/private/field-templates/image-field-template/image-field-template.component.mjs +82 -43
  6. package/esm2020/lib/components/private/form-records/add-form-record/add-form-record.component.mjs +48 -70
  7. package/esm2020/lib/components/private/form-records/list-view-form-record/list-view-form-record.component.mjs +1 -1
  8. package/esm2020/lib/components/private/form-records/list-view-form-record/single-record/single-record.component.mjs +3 -2
  9. package/esm2020/lib/components/private/tmw-image-drawer/i18n.mjs +63 -0
  10. package/esm2020/lib/components/private/tmw-image-drawer/tmw-image-drawer.component.mjs +403 -0
  11. package/esm2020/lib/eqp-dynamic-module.module.mjs +6 -3
  12. package/esm2020/lib/models/endPointConfiguration.model.mjs +24 -1
  13. package/esm2020/lib/models/fields/imageField.model.mjs +7 -14
  14. package/esm2020/lib/models/fields/imageSelectorField.model.mjs +2 -1
  15. package/esm2020/lib/services/utilityHelper.services.mjs +1 -1
  16. package/fesm2015/eqproject-eqp-dynamic-module.mjs +933 -422
  17. package/fesm2015/eqproject-eqp-dynamic-module.mjs.map +1 -1
  18. package/fesm2020/eqproject-eqp-dynamic-module.mjs +773 -270
  19. package/fesm2020/eqproject-eqp-dynamic-module.mjs.map +1 -1
  20. package/lib/components/private/dynamic-module-field-fix/dynamic-module-field.component.d.ts +6 -1
  21. package/lib/components/private/field-templates/image-field-template/image-field-template.component.d.ts +18 -5
  22. package/lib/components/private/form-records/add-form-record/add-form-record.component.d.ts +5 -2
  23. package/lib/components/private/tmw-image-drawer/i18n.d.ts +27 -0
  24. package/lib/components/private/tmw-image-drawer/tmw-image-drawer.component.d.ts +70 -0
  25. package/lib/eqp-dynamic-module.module.d.ts +13 -12
  26. package/lib/models/endPointConfiguration.model.d.ts +2 -0
  27. package/lib/models/fields/imageField.model.d.ts +5 -0
  28. package/lib/models/fields/imageSelectorField.model.d.ts +3 -0
  29. package/lib/services/utilityHelper.services.d.ts +2 -1
  30. package/package.json +1 -2
@@ -0,0 +1,403 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { I18nEn, i18nLanguages } from './i18n';
3
+ import { fabric } from 'fabric';
4
+ import { Observable, of } from 'rxjs';
5
+ import { switchMap } from 'rxjs/operators';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/material/icon";
8
+ import * as i2 from "@angular/common";
9
+ export class TmwImageDrawerComponent {
10
+ constructor() {
11
+ this.closeDialog = new EventEmitter();
12
+ this.forceSizeCanvas = true;
13
+ this.forceSizeExport = false;
14
+ this.enableRemoveImage = false;
15
+ this.enableLoadAnotherImage = false;
16
+ this.enableTooltip = false;
17
+ this.showCancelButton = true;
18
+ this.inConfig = false;
19
+ this.locale = 'en';
20
+ this.outputMimeType = 'image/jpeg';
21
+ this.outputQuality = 0.8;
22
+ this.borderCss = 'none';
23
+ this.drawingSizes = {
24
+ small: 5,
25
+ medium: 10,
26
+ large: 25,
27
+ };
28
+ this.colors = {
29
+ black: '#000',
30
+ white: '#fff',
31
+ yellow: '#ffeb3b',
32
+ red: '#f44336',
33
+ blue: '#2196f3',
34
+ green: '#4caf50',
35
+ purple: '#7a08af',
36
+ };
37
+ this.save = new EventEmitter();
38
+ this.loadOriginal = new EventEmitter();
39
+ this.currentTool = 'brush';
40
+ this.currentSize = 'medium';
41
+ this.currentColor = 'black';
42
+ this.i18n = I18nEn;
43
+ this.canUndo = false;
44
+ this.canRedo = false;
45
+ this.isLoading = true;
46
+ this.hasError = false;
47
+ this.errorMessage = '';
48
+ this.stack = [];
49
+ this.colorsName = [];
50
+ this.drawingSizesName = [];
51
+ }
52
+ ngOnInit() {
53
+ this.componentGuid = 'xxxx-xxxx-xxxx-xxxx'.replace(/[xy]/g, function (c) {
54
+ var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8);
55
+ return v.toString(16);
56
+ });
57
+ }
58
+ ngAfterViewInit() {
59
+ this.isLoading = false;
60
+ this.colorsName = Object.keys(this.colors);
61
+ this.drawingSizesName = Object.keys(this.drawingSizes);
62
+ const canvasScaledElement = document.getElementById(this.componentGuid);
63
+ this.canvas = new fabric.Canvas(canvasScaledElement, {
64
+ hoverCursor: 'pointer',
65
+ isDrawingMode: true,
66
+ });
67
+ this.canvas.backgroundColor = 'white';
68
+ if (this.src) {
69
+ this.importPhotoFromSrc(this.src);
70
+ }
71
+ else {
72
+ if (!this.width || !this.height) {
73
+ throw new Error('No width or hight given !');
74
+ }
75
+ this.canvas.setWidth(this.width);
76
+ this.canvas.setHeight(this.height);
77
+ }
78
+ this.canvas.on('path:created', () => {
79
+ this.stack = [];
80
+ this.setUndoRedo();
81
+ });
82
+ this.selectTool(this.currentTool);
83
+ this.selectColor(this.currentColor);
84
+ this.selectDrawingSize(this.currentSize);
85
+ if (this.locale && i18nLanguages[this.locale.toLowerCase()]) {
86
+ this.i18n = i18nLanguages[this.locale.toLowerCase()];
87
+ }
88
+ }
89
+ ngOnChanges(changes) {
90
+ if (changes.src && !changes.src.firstChange && changes.src.currentValue) {
91
+ if (typeof changes.src.currentValue === 'string') {
92
+ this.importPhotoFromSrc(changes.src.currentValue);
93
+ }
94
+ else if (changes.src.currentValue instanceof Blob) {
95
+ this.importPhotoFromBlob(changes.src.currentValue);
96
+ }
97
+ }
98
+ }
99
+ // Tools
100
+ selectTool(tool) {
101
+ this.currentTool = tool;
102
+ }
103
+ selectDrawingSize(size) {
104
+ this.currentSize = size;
105
+ if (this.canvas) {
106
+ this.canvas.freeDrawingBrush.width = this.drawingSizes[size];
107
+ }
108
+ }
109
+ selectColor(color) {
110
+ this.currentColor = color;
111
+ if (this.canvas) {
112
+ this.canvas.freeDrawingBrush.color = this.colors[color];
113
+ }
114
+ }
115
+ // Actions
116
+ undo() {
117
+ if (this.canUndo) {
118
+ const lastId = this.canvas.getObjects().length - 1;
119
+ const lastObj = this.canvas.getObjects()[lastId];
120
+ this.stack.push(lastObj);
121
+ this.canvas.remove(lastObj);
122
+ this.setUndoRedo();
123
+ }
124
+ }
125
+ redo() {
126
+ if (this.canRedo) {
127
+ const firstInStack = this.stack.splice(-1, 1)[0];
128
+ if (firstInStack) {
129
+ this.canvas.insertAt(firstInStack, this.canvas.getObjects().length - 1, false);
130
+ }
131
+ this.setUndoRedo();
132
+ }
133
+ }
134
+ clearCanvas() {
135
+ if (this.canvas) {
136
+ this.canvas.remove(...this.canvas.getObjects());
137
+ this.setUndoRedo();
138
+ }
139
+ }
140
+ saveImage() {
141
+ if (!this.forceSizeExport || (this.forceSizeExport && this.width && this.height)) {
142
+ const canvasScaledElement = document.createElement('canvas');
143
+ const canvasScaled = new fabric.Canvas(canvasScaledElement);
144
+ canvasScaled.backgroundColor = 'white';
145
+ new Observable(observer => {
146
+ if (this.imageUsed) {
147
+ if (this.forceSizeExport) {
148
+ canvasScaled.setWidth(this.width);
149
+ canvasScaled.setHeight(this.height);
150
+ this.imageUsed.cloneAsImage(imageCloned => {
151
+ imageCloned.scaleToWidth(this.width, false);
152
+ imageCloned.scaleToHeight(this.height, false);
153
+ canvasScaled.setBackgroundImage(imageCloned, (img) => {
154
+ if (!img) {
155
+ observer.error(new Error('Impossible to draw the image on the temporary canvas'));
156
+ }
157
+ observer.next(canvasScaled);
158
+ observer.complete();
159
+ }, {
160
+ crossOrigin: 'anonymous',
161
+ originX: 'left',
162
+ originY: 'top'
163
+ });
164
+ });
165
+ }
166
+ else {
167
+ canvasScaled.setBackgroundImage(this.imageUsed, (img) => {
168
+ if (!img) {
169
+ observer.error(new Error('Impossible to draw the image on the temporary canvas'));
170
+ }
171
+ canvasScaled.setWidth(img.width);
172
+ canvasScaled.setHeight(img.height);
173
+ observer.next(canvasScaled);
174
+ observer.complete();
175
+ }, {
176
+ crossOrigin: 'anonymous',
177
+ originX: 'left',
178
+ originY: 'top'
179
+ });
180
+ }
181
+ }
182
+ else {
183
+ canvasScaled.setWidth(this.width);
184
+ canvasScaled.setHeight(this.height);
185
+ }
186
+ }).pipe(switchMap(() => {
187
+ let process = of(canvasScaled);
188
+ if (this.canvas.getObjects().length > 0) {
189
+ const ratioX = canvasScaled.getWidth() / this.canvas.getWidth();
190
+ const ratioY = canvasScaled.getHeight() / this.canvas.getHeight();
191
+ this.canvas.getObjects().forEach((originalObject, i) => {
192
+ process = process.pipe(switchMap(() => {
193
+ return new Observable(observerObject => {
194
+ originalObject.clone((clonedObject) => {
195
+ clonedObject.set('left', originalObject.left * ratioX);
196
+ clonedObject.set('top', originalObject.top * ratioY);
197
+ clonedObject.scaleToWidth(originalObject.width * ratioX);
198
+ clonedObject.scaleToHeight(originalObject.height * ratioY);
199
+ canvasScaled.insertAt(clonedObject, i, false);
200
+ canvasScaled.renderAll();
201
+ observerObject.next(canvasScaled);
202
+ observerObject.complete();
203
+ });
204
+ });
205
+ }));
206
+ });
207
+ }
208
+ return process;
209
+ })).subscribe(() => {
210
+ canvasScaled.renderAll();
211
+ canvasScaled.getElement().toBlob((data) => {
212
+ this.save.emit(data);
213
+ }, this.outputMimeType, this.outputQuality);
214
+ });
215
+ }
216
+ else {
217
+ this.canvas.getElement().toBlob((data) => {
218
+ this.save.emit(data);
219
+ }, this.outputMimeType, this.outputQuality);
220
+ }
221
+ }
222
+ doLoadOriginal() {
223
+ this.loadOriginal.emit();
224
+ }
225
+ getTextTranslated(name) {
226
+ let strOk = name.split('.').reduce((o, i) => o[i], this.i18n);
227
+ if (this.i18nUser) {
228
+ try {
229
+ const str = name.split('.').reduce((o, i) => o[i], this.i18nUser);
230
+ if (str) {
231
+ strOk = str;
232
+ }
233
+ }
234
+ catch (e) {
235
+ // if we pass here, ignored
236
+ }
237
+ }
238
+ if (!strOk) {
239
+ console.error(name + ' translation not found !');
240
+ }
241
+ return strOk;
242
+ }
243
+ getTooltipTranslated(name) {
244
+ if (this.enableTooltip) {
245
+ return this.getTextTranslated(name);
246
+ }
247
+ else {
248
+ return '';
249
+ }
250
+ }
251
+ setUndoRedo() {
252
+ this.canUndo = this.canvas.getObjects().length > 0;
253
+ this.canRedo = this.stack.length > 0;
254
+ // this.canvas.renderAll();
255
+ }
256
+ importPhotoFromFile(event) {
257
+ if (event.target.files && event.target.files.length > 0) {
258
+ const file = event.target.files[0];
259
+ if (file.type.match('image.*')) {
260
+ this.importPhotoFromBlob(file);
261
+ }
262
+ else {
263
+ throw new Error('Not an image !');
264
+ }
265
+ }
266
+ }
267
+ removeImage() {
268
+ if (this.imageUsed) {
269
+ this.imageUsed.dispose();
270
+ this.imageUsed = null;
271
+ }
272
+ this.canvas.backgroundImage = null;
273
+ if (this.width && this.height) {
274
+ this.canvas.setWidth(this.width);
275
+ this.canvas.setHeight(this.height);
276
+ }
277
+ this.canvas.renderAll();
278
+ }
279
+ get hasImage() {
280
+ return !!this.canvas.backgroundImage;
281
+ }
282
+ importPhotoFromSrc(src) {
283
+ this.isLoading = true;
284
+ let isFirstTry = true;
285
+ const imgEl = new Image();
286
+ imgEl.setAttribute('crossOrigin', 'anonymous');
287
+ imgEl.src = src;
288
+ imgEl.onerror = () => {
289
+ // Retry with cors proxy
290
+ if (isFirstTry) {
291
+ imgEl.src = 'https://cors-anywhere.herokuapp.com/' + this.src;
292
+ isFirstTry = false;
293
+ }
294
+ else {
295
+ this.isLoading = false;
296
+ this.hasError = true;
297
+ this.errorMessage = this.getTextTranslated('loadError').replace('%@', this.src);
298
+ }
299
+ };
300
+ imgEl.onload = () => {
301
+ this.isLoading = false;
302
+ this.imageUsed = new fabric.Image(imgEl);
303
+ this.imageUsed.cloneAsImage(image => {
304
+ let width = imgEl.width;
305
+ let height = imgEl.height;
306
+ if (this.width) {
307
+ width = this.width;
308
+ }
309
+ if (this.height) {
310
+ height = this.height;
311
+ }
312
+ image.scaleToWidth(width, false);
313
+ image.scaleToHeight(height, false);
314
+ this.canvas.setBackgroundImage(image, ((img) => {
315
+ if (img) {
316
+ if (this.forceSizeCanvas) {
317
+ this.canvas.setWidth(width);
318
+ this.canvas.setHeight(height);
319
+ }
320
+ else {
321
+ this.canvas.setWidth(image.getScaledWidth());
322
+ this.canvas.setHeight(image.getScaledHeight());
323
+ }
324
+ }
325
+ }), {
326
+ crossOrigin: 'anonymous',
327
+ originX: 'left',
328
+ originY: 'top'
329
+ });
330
+ });
331
+ };
332
+ }
333
+ importPhotoFromBlob(file) {
334
+ const reader = new FileReader();
335
+ reader.readAsDataURL(file);
336
+ reader.onload = (evtReader) => {
337
+ if (evtReader.target.readyState == FileReader.DONE) {
338
+ this.importPhotoFromSrc(evtReader.target.result);
339
+ }
340
+ };
341
+ }
342
+ importPhotoFromUrl() {
343
+ const url = prompt(this.getTooltipTranslated('loadImageUrl'));
344
+ if (url) {
345
+ this.importPhotoFromSrc(url);
346
+ }
347
+ }
348
+ close() {
349
+ this.closeDialog.emit();
350
+ }
351
+ }
352
+ TmwImageDrawerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TmwImageDrawerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
353
+ TmwImageDrawerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TmwImageDrawerComponent, selector: "tmw-image-drawer", inputs: { src: "src", width: "width", height: "height", forceSizeCanvas: "forceSizeCanvas", forceSizeExport: "forceSizeExport", enableRemoveImage: "enableRemoveImage", enableLoadAnotherImage: "enableLoadAnotherImage", enableTooltip: "enableTooltip", showCancelButton: "showCancelButton", inConfig: "inConfig", i18nUser: ["i18n", "i18nUser"], locale: "locale", loadingTemplate: "loadingTemplate", errorTemplate: "errorTemplate", outputMimeType: "outputMimeType", outputQuality: "outputQuality", borderCss: "borderCss", drawingSizes: "drawingSizes", colors: "colors" }, outputs: { closeDialog: "closeDialog", save: "save", loadOriginal: "loadOriginal" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"loading\" *ngIf=\"isLoading && loadingTemplate\">\r\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\r\n</div>\r\n<div class=\"error\" *ngIf=\"hasError\">\r\n <ng-container *ngTemplateOutlet=\"errorTemplate ? errorTemplate : defaultError\"></ng-container>\r\n</div>\r\n\r\n<!-- <ng-template #defaultLoading>\r\n <p>{{ getTextTranslated('loading') }}</p>\r\n</ng-template> -->\r\n<ng-template #defaultError>\r\n <p>{{ errorMessage }}</p>\r\n</ng-template>\r\n\r\n<div class=\"toolbar\" *ngIf=\"!isLoading\">\r\n <div class=\"tools\">\r\n\r\n <div class=\"brush\">\r\n <i class=\"title\">tools</i>\r\n <div class=\"internal\">\r\n <i class=\"material-icons btn\" [class.selected]=\"currentTool == 'brush'\" (click)=\"selectTool('brush')\"\r\n [title]=\"getTooltipTranslated('tools.brush')\"><mat-icon>brush</mat-icon></i>\r\n <span *ngFor=\"let drawingSizeName of drawingSizesName\" class=\"size btn mr-1\"\r\n [style.width.px]=\"drawingSizes[drawingSizeName] * 0.8 + 8\"\r\n [style.height.px]=\"drawingSizes[drawingSizeName] * 0.8 + 8\"\r\n [style.borderRadius.px]=\"drawingSizes[drawingSizeName] * 0.4 + 4\"\r\n [class.selected]=\"currentSize == drawingSizeName\" [title]=\"getTooltipTranslated('sizes.' + drawingSizeName)\"\r\n (click)=\"selectDrawingSize(drawingSizeName)\">\r\n </span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"commands\">\r\n <i class=\"title\">options</i>\r\n <div class=\"internal\">\r\n <i class=\"material-icons btn\" [class.disabled]=\"!canUndo\" (click)=\"undo()\"\r\n [title]=\"getTooltipTranslated('undo')\"><mat-icon>undo</mat-icon></i>\r\n <i class=\"material-icons btn\" [class.disabled]=\"!canRedo\" (click)=\"redo()\"\r\n [title]=\"getTooltipTranslated('redo')\"><mat-icon>redo</mat-icon></i>\r\n <i class=\"material-icons btn\" (click)=\"clearCanvas()\" [title]=\"getTooltipTranslated('clear')\"><mat-icon>clear</mat-icon></i>\r\n </div>\r\n </div>\r\n\r\n <div class=\"colors\">\r\n <i class=\"title\">colors</i>\r\n <div class=\"internal\">\r\n <div *ngFor=\"let colorName of colorsName\" [class.selected]=\"currentColor == colorName\" class=\"color\"\r\n [ngClass]=\"colorName\" [style.background]=\"colors[colorName]\"\r\n [title]=\"getTooltipTranslated('colors.' + colorName)\" (click)=\"selectColor(colorName)\">\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"actions\">\r\n <i class=\"title\">actions</i>\r\n <div class=\"internal\">\r\n <a href=\"#\" class=\"btn btn-success\" (click)=\"saveImage(); $event.preventDefault()\" *ngIf=\"!inConfig\">{{\r\n getTextTranslated('saveBtn') }}</a>\r\n <a href=\"#\" class=\"btn btn-warning\" *ngIf=\"showCancelButton && !inConfig\" (click)=\"doLoadOriginal(); $event.preventDefault()\">{{\r\n getTextTranslated('cancelBtn') }}</a>\r\n <a href=\"#\" class=\"btn btn-danger\" *ngIf=\"showCancelButton\" (click)=\"close(); $event.preventDefault()\">{{\r\n getTextTranslated('closeDialog') }}</a>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n <!-- Any additional toolbar buttons to be projected by the consuming app -->\r\n <ng-content></ng-content>\r\n</div>\r\n\r\n<div [ngStyle]=\"{ border: borderCss }\">\r\n <canvas [id]=\"componentGuid\"></canvas>\r\n</div>", styles: [":host{display:flex;flex-direction:column;align-items:center}:host .toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}:host .tools{display:inline-flex;flex-direction:row;margin:10px;background:#fff;border-radius:6px;box-shadow:0 3px 10px #0006}:host .tools .brush,:host .tools .commands,:host .tools .colors,:host .tools .actions{display:flex}:host .tools .brush .title,:host .tools .commands .title,:host .tools .colors .title,:host .tools .actions .title{display:flex;vertical-align:middle;background-color:#00a8ff;color:#fff;padding:10px}:host .tools .brush .internal,:host .tools .commands .internal,:host .tools .colors .internal,:host .tools .actions .internal{display:flex;vertical-align:middle;align-items:center;padding:0 15px}:host .tools .brush .internal>*,:host .tools .commands .internal>*,:host .tools .colors .internal>*,:host .tools .actions .internal>*{margin-right:5px}:host .tools .brush .internal .disabled,:host .tools .commands .internal .disabled,:host .tools .colors .internal .disabled,:host .tools .actions .internal .disabled{border:0;color:red}:host .row{display:flex;justify-content:space-around;align-items:center}:host .row:first-child{margin-bottom:10px}:host .size{background-color:#000}:host .size.selected{background-color:#bdbdbd}:host .color{width:28px;height:28px;border-radius:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}:host .color.selected:after{content:\"\";width:10px;height:10px;background:#000;display:flex;border-radius:5px}:host .color.black{background-color:#000}:host .color.black.selected:after{background:#fff}:host .color.white{border:1px solid #a7a7a7}:host .buttons{margin:10px;display:flex;flex-direction:column}:host .button{cursor:pointer;outline:0;border:none;white-space:nowrap;text-decoration:none;vertical-align:baseline;text-align:center;min-width:64px;line-height:36px;padding:3px 16px;border-radius:4px;overflow:visible;transition:background .4s cubic-bezier(.25,.8,.25,1),box-shadow .28s cubic-bezier(.4,0,.2,1);margin:10px}:host .button:hover{text-decoration:none!important}\n"], dependencies: [{ kind: "component", type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
354
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TmwImageDrawerComponent, decorators: [{
355
+ type: Component,
356
+ args: [{ selector: 'tmw-image-drawer', template: "<div class=\"loading\" *ngIf=\"isLoading && loadingTemplate\">\r\n <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\r\n</div>\r\n<div class=\"error\" *ngIf=\"hasError\">\r\n <ng-container *ngTemplateOutlet=\"errorTemplate ? errorTemplate : defaultError\"></ng-container>\r\n</div>\r\n\r\n<!-- <ng-template #defaultLoading>\r\n <p>{{ getTextTranslated('loading') }}</p>\r\n</ng-template> -->\r\n<ng-template #defaultError>\r\n <p>{{ errorMessage }}</p>\r\n</ng-template>\r\n\r\n<div class=\"toolbar\" *ngIf=\"!isLoading\">\r\n <div class=\"tools\">\r\n\r\n <div class=\"brush\">\r\n <i class=\"title\">tools</i>\r\n <div class=\"internal\">\r\n <i class=\"material-icons btn\" [class.selected]=\"currentTool == 'brush'\" (click)=\"selectTool('brush')\"\r\n [title]=\"getTooltipTranslated('tools.brush')\"><mat-icon>brush</mat-icon></i>\r\n <span *ngFor=\"let drawingSizeName of drawingSizesName\" class=\"size btn mr-1\"\r\n [style.width.px]=\"drawingSizes[drawingSizeName] * 0.8 + 8\"\r\n [style.height.px]=\"drawingSizes[drawingSizeName] * 0.8 + 8\"\r\n [style.borderRadius.px]=\"drawingSizes[drawingSizeName] * 0.4 + 4\"\r\n [class.selected]=\"currentSize == drawingSizeName\" [title]=\"getTooltipTranslated('sizes.' + drawingSizeName)\"\r\n (click)=\"selectDrawingSize(drawingSizeName)\">\r\n </span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"commands\">\r\n <i class=\"title\">options</i>\r\n <div class=\"internal\">\r\n <i class=\"material-icons btn\" [class.disabled]=\"!canUndo\" (click)=\"undo()\"\r\n [title]=\"getTooltipTranslated('undo')\"><mat-icon>undo</mat-icon></i>\r\n <i class=\"material-icons btn\" [class.disabled]=\"!canRedo\" (click)=\"redo()\"\r\n [title]=\"getTooltipTranslated('redo')\"><mat-icon>redo</mat-icon></i>\r\n <i class=\"material-icons btn\" (click)=\"clearCanvas()\" [title]=\"getTooltipTranslated('clear')\"><mat-icon>clear</mat-icon></i>\r\n </div>\r\n </div>\r\n\r\n <div class=\"colors\">\r\n <i class=\"title\">colors</i>\r\n <div class=\"internal\">\r\n <div *ngFor=\"let colorName of colorsName\" [class.selected]=\"currentColor == colorName\" class=\"color\"\r\n [ngClass]=\"colorName\" [style.background]=\"colors[colorName]\"\r\n [title]=\"getTooltipTranslated('colors.' + colorName)\" (click)=\"selectColor(colorName)\">\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"actions\">\r\n <i class=\"title\">actions</i>\r\n <div class=\"internal\">\r\n <a href=\"#\" class=\"btn btn-success\" (click)=\"saveImage(); $event.preventDefault()\" *ngIf=\"!inConfig\">{{\r\n getTextTranslated('saveBtn') }}</a>\r\n <a href=\"#\" class=\"btn btn-warning\" *ngIf=\"showCancelButton && !inConfig\" (click)=\"doLoadOriginal(); $event.preventDefault()\">{{\r\n getTextTranslated('cancelBtn') }}</a>\r\n <a href=\"#\" class=\"btn btn-danger\" *ngIf=\"showCancelButton\" (click)=\"close(); $event.preventDefault()\">{{\r\n getTextTranslated('closeDialog') }}</a>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n <!-- Any additional toolbar buttons to be projected by the consuming app -->\r\n <ng-content></ng-content>\r\n</div>\r\n\r\n<div [ngStyle]=\"{ border: borderCss }\">\r\n <canvas [id]=\"componentGuid\"></canvas>\r\n</div>", styles: [":host{display:flex;flex-direction:column;align-items:center}:host .toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}:host .tools{display:inline-flex;flex-direction:row;margin:10px;background:#fff;border-radius:6px;box-shadow:0 3px 10px #0006}:host .tools .brush,:host .tools .commands,:host .tools .colors,:host .tools .actions{display:flex}:host .tools .brush .title,:host .tools .commands .title,:host .tools .colors .title,:host .tools .actions .title{display:flex;vertical-align:middle;background-color:#00a8ff;color:#fff;padding:10px}:host .tools .brush .internal,:host .tools .commands .internal,:host .tools .colors .internal,:host .tools .actions .internal{display:flex;vertical-align:middle;align-items:center;padding:0 15px}:host .tools .brush .internal>*,:host .tools .commands .internal>*,:host .tools .colors .internal>*,:host .tools .actions .internal>*{margin-right:5px}:host .tools .brush .internal .disabled,:host .tools .commands .internal .disabled,:host .tools .colors .internal .disabled,:host .tools .actions .internal .disabled{border:0;color:red}:host .row{display:flex;justify-content:space-around;align-items:center}:host .row:first-child{margin-bottom:10px}:host .size{background-color:#000}:host .size.selected{background-color:#bdbdbd}:host .color{width:28px;height:28px;border-radius:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}:host .color.selected:after{content:\"\";width:10px;height:10px;background:#000;display:flex;border-radius:5px}:host .color.black{background-color:#000}:host .color.black.selected:after{background:#fff}:host .color.white{border:1px solid #a7a7a7}:host .buttons{margin:10px;display:flex;flex-direction:column}:host .button{cursor:pointer;outline:0;border:none;white-space:nowrap;text-decoration:none;vertical-align:baseline;text-align:center;min-width:64px;line-height:36px;padding:3px 16px;border-radius:4px;overflow:visible;transition:background .4s cubic-bezier(.25,.8,.25,1),box-shadow .28s cubic-bezier(.4,0,.2,1);margin:10px}:host .button:hover{text-decoration:none!important}\n"] }]
357
+ }], ctorParameters: function () { return []; }, propDecorators: { closeDialog: [{
358
+ type: Output
359
+ }], src: [{
360
+ type: Input
361
+ }], width: [{
362
+ type: Input
363
+ }], height: [{
364
+ type: Input
365
+ }], forceSizeCanvas: [{
366
+ type: Input
367
+ }], forceSizeExport: [{
368
+ type: Input
369
+ }], enableRemoveImage: [{
370
+ type: Input
371
+ }], enableLoadAnotherImage: [{
372
+ type: Input
373
+ }], enableTooltip: [{
374
+ type: Input
375
+ }], showCancelButton: [{
376
+ type: Input
377
+ }], inConfig: [{
378
+ type: Input
379
+ }], i18nUser: [{
380
+ type: Input,
381
+ args: ['i18n']
382
+ }], locale: [{
383
+ type: Input
384
+ }], loadingTemplate: [{
385
+ type: Input
386
+ }], errorTemplate: [{
387
+ type: Input
388
+ }], outputMimeType: [{
389
+ type: Input
390
+ }], outputQuality: [{
391
+ type: Input
392
+ }], borderCss: [{
393
+ type: Input
394
+ }], drawingSizes: [{
395
+ type: Input
396
+ }], colors: [{
397
+ type: Input
398
+ }], save: [{
399
+ type: Output
400
+ }], loadOriginal: [{
401
+ type: Output
402
+ }] } });
403
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tmw-image-drawer.component.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/tmw-image-drawer/tmw-image-drawer.component.ts","../../../../../../../projects/eqp-dynamic-module/src/lib/components/private/tmw-image-drawer/tmw-image-drawer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, TemplateRef } from '@angular/core';\r\nimport { I18nEn, I18nInterface, i18nLanguages } from './i18n';\r\nimport { fabric } from 'fabric';\r\nimport { Observable, of } from 'rxjs';\r\nimport { switchMap } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: 'tmw-image-drawer',\r\n  templateUrl: './tmw-image-drawer.component.html',\r\n  styleUrls: ['./tmw-image-drawer.component.scss']\r\n})\r\nexport class TmwImageDrawerComponent implements OnInit, AfterViewInit, OnChanges {\r\n\r\n  @Output() closeDialog: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Input() public src?: string;\r\n  @Input() public width?: number;\r\n  @Input() public height?: number;\r\n\r\n  @Input() public forceSizeCanvas = true;\r\n  @Input() public forceSizeExport = false;\r\n  @Input() public enableRemoveImage = false;\r\n  @Input() public enableLoadAnotherImage = false;\r\n  @Input() public enableTooltip = false;\r\n  @Input() public showCancelButton = true;\r\n\r\n  @Input() public inConfig?: boolean = false;\r\n\r\n  // @ts-ignore\r\n  @Input('i18n') public i18nUser: I18nInterface;\r\n  @Input() public locale: string = 'en';\r\n\r\n  @Input() public loadingTemplate?: TemplateRef<any>;\r\n  @Input() public errorTemplate?: TemplateRef<any>;\r\n\r\n  @Input() public outputMimeType = 'image/jpeg';\r\n  @Input() public outputQuality = 0.8;\r\n\r\n  @Input() public borderCss: string = 'none';\r\n\r\n  @Input() public drawingSizes: { [name: string]: number } = {\r\n    small: 5,\r\n    medium: 10,\r\n    large: 25,\r\n  };\r\n\r\n  @Input() public colors: { [name: string]: string } = {\r\n    black: '#000',\r\n    white: '#fff',\r\n    yellow: '#ffeb3b',\r\n    red: '#f44336',\r\n    blue: '#2196f3',\r\n    green: '#4caf50',\r\n    purple: '#7a08af',\r\n  };\r\n\r\n  @Output() public save: EventEmitter<Blob> = new EventEmitter<Blob>();\r\n  @Output() public loadOriginal: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  public currentTool = 'brush';\r\n  public currentSize = 'medium';\r\n  public currentColor = 'black';\r\n  public i18n: I18nInterface = I18nEn;\r\n\r\n  public canUndo = false;\r\n  public canRedo = false;\r\n\r\n  public isLoading = true;\r\n  public hasError = false;\r\n  public errorMessage = '';\r\n\r\n  private canvas: fabric.Canvas;\r\n  private stack: fabric.Object[] = [];\r\n\r\n  public colorsName: string[] = [];\r\n  public drawingSizesName: string[] = [];\r\n\r\n  private imageUsed?: fabric.Image;\r\n\r\n  componentGuid: string;\r\n\r\n  constructor() {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.componentGuid = 'xxxx-xxxx-xxxx-xxxx'.replace(/[xy]/g, function (c) {\r\n      var r = Math.random() * 16 | 0,\r\n        v = c == 'x' ? r : (r & 0x3 | 0x8);\r\n      return v.toString(16);\r\n    });\r\n  }\r\n\r\n  public ngAfterViewInit(): void {\r\n    this.isLoading = false\r\n    this.colorsName = Object.keys(this.colors);\r\n    this.drawingSizesName = Object.keys(this.drawingSizes);\r\n\r\n    const canvasScaledElement = document.getElementById(this.componentGuid);\r\n    this.canvas = new fabric.Canvas(canvasScaledElement, {\r\n      hoverCursor: 'pointer',\r\n      isDrawingMode: true,\r\n    });\r\n    this.canvas.backgroundColor = 'white';\r\n\r\n    if (this.src) {\r\n      this.importPhotoFromSrc(this.src);\r\n    } else {\r\n      if (!this.width || !this.height) {\r\n        throw new Error('No width or hight given !');\r\n      }\r\n\r\n      this.canvas.setWidth(this.width);\r\n      this.canvas.setHeight(this.height);\r\n    }\r\n\r\n    this.canvas.on('path:created', () => {\r\n      this.stack = [];\r\n      this.setUndoRedo();\r\n    });\r\n\r\n    this.selectTool(this.currentTool);\r\n    this.selectColor(this.currentColor);\r\n    this.selectDrawingSize(this.currentSize);\r\n\r\n    if (this.locale && i18nLanguages[this.locale.toLowerCase()]) {\r\n      this.i18n = i18nLanguages[this.locale.toLowerCase()];\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.src && !changes.src.firstChange && changes.src.currentValue) {\r\n      if (typeof changes.src.currentValue === 'string') {\r\n        this.importPhotoFromSrc(changes.src.currentValue);\r\n      } else if (changes.src.currentValue instanceof Blob) {\r\n        this.importPhotoFromBlob(changes.src.currentValue);\r\n      }\r\n    }\r\n  }\r\n\r\n  // Tools\r\n  public selectTool(tool: string) {\r\n    this.currentTool = tool;\r\n  }\r\n\r\n  public selectDrawingSize(size: string) {\r\n    this.currentSize = size;\r\n    if (this.canvas) {\r\n      this.canvas.freeDrawingBrush.width = this.drawingSizes[size];\r\n    }\r\n  }\r\n\r\n  public selectColor(color: string) {\r\n    this.currentColor = color;\r\n    if (this.canvas) {\r\n      this.canvas.freeDrawingBrush.color = this.colors[color];\r\n    }\r\n  }\r\n\r\n  // Actions\r\n  public undo() {\r\n    if (this.canUndo) {\r\n      const lastId = this.canvas.getObjects().length - 1;\r\n      const lastObj = this.canvas.getObjects()[lastId];\r\n      this.stack.push(lastObj);\r\n      this.canvas.remove(lastObj);\r\n      this.setUndoRedo();\r\n    }\r\n  }\r\n\r\n  public redo() {\r\n    if (this.canRedo) {\r\n      const firstInStack = this.stack.splice(-1, 1)[0];\r\n      if (firstInStack) {\r\n        this.canvas.insertAt(firstInStack, this.canvas.getObjects().length - 1, false);\r\n      }\r\n      this.setUndoRedo();\r\n    }\r\n  }\r\n\r\n  public clearCanvas() {\r\n    if (this.canvas) {\r\n      this.canvas.remove(...this.canvas.getObjects());\r\n      this.setUndoRedo();\r\n    }\r\n  }\r\n\r\n  public saveImage() {\r\n    if (!this.forceSizeExport || (this.forceSizeExport && this.width && this.height)) {\r\n      const canvasScaledElement: HTMLCanvasElement = document.createElement('canvas');\r\n      const canvasScaled = new fabric.Canvas(canvasScaledElement);\r\n      canvasScaled.backgroundColor = 'white';\r\n\r\n      new Observable<fabric.Canvas>(observer => {\r\n        if (this.imageUsed) {\r\n          if (this.forceSizeExport) {\r\n            canvasScaled.setWidth(this.width);\r\n            canvasScaled.setHeight(this.height);\r\n\r\n            this.imageUsed.cloneAsImage(imageCloned => {\r\n              imageCloned.scaleToWidth(this.width, false);\r\n              imageCloned.scaleToHeight(this.height, false);\r\n\r\n              canvasScaled.setBackgroundImage(imageCloned, (img: HTMLImageElement) => {\r\n                if (!img) {\r\n                  observer.error(new Error('Impossible to draw the image on the temporary canvas'));\r\n                }\r\n\r\n                observer.next(canvasScaled);\r\n                observer.complete();\r\n              }, {\r\n                crossOrigin: 'anonymous',\r\n                originX: 'left',\r\n                originY: 'top'\r\n              });\r\n            });\r\n          } else {\r\n            canvasScaled.setBackgroundImage(this.imageUsed, (img: HTMLImageElement) => {\r\n              if (!img) {\r\n                observer.error(new Error('Impossible to draw the image on the temporary canvas'));\r\n              }\r\n\r\n              canvasScaled.setWidth(img.width);\r\n              canvasScaled.setHeight(img.height);\r\n\r\n              observer.next(canvasScaled);\r\n              observer.complete();\r\n            }, {\r\n              crossOrigin: 'anonymous',\r\n              originX: 'left',\r\n              originY: 'top'\r\n            });\r\n          }\r\n        } else {\r\n          canvasScaled.setWidth(this.width);\r\n          canvasScaled.setHeight(this.height);\r\n        }\r\n      }).pipe(\r\n        switchMap(() => {\r\n          let process = of(canvasScaled);\r\n\r\n          if (this.canvas.getObjects().length > 0) {\r\n            const ratioX = canvasScaled.getWidth() / this.canvas.getWidth();\r\n            const ratioY = canvasScaled.getHeight() / this.canvas.getHeight();\r\n\r\n            this.canvas.getObjects().forEach((originalObject: fabric.Object, i: number) => {\r\n              process = process.pipe(switchMap(() => {\r\n                return new Observable<fabric.Canvas>(observerObject => {\r\n                  originalObject.clone((clonedObject: fabric.Object) => {\r\n                    clonedObject.set('left', originalObject.left * ratioX);\r\n                    clonedObject.set('top', originalObject.top * ratioY);\r\n                    clonedObject.scaleToWidth(originalObject.width * ratioX);\r\n                    clonedObject.scaleToHeight(originalObject.height * ratioY);\r\n\r\n                    canvasScaled.insertAt(clonedObject, i, false);\r\n                    canvasScaled.renderAll();\r\n\r\n                    observerObject.next(canvasScaled);\r\n                    observerObject.complete();\r\n                  });\r\n                });\r\n              }));\r\n            });\r\n          }\r\n          return process;\r\n        }),\r\n      ).subscribe(() => {\r\n        canvasScaled.renderAll();\r\n        canvasScaled.getElement().toBlob(\r\n          (data: Blob) => {\r\n            this.save.emit(data);\r\n          },\r\n          this.outputMimeType,\r\n          this.outputQuality\r\n        );\r\n      });\r\n    } else {\r\n      this.canvas.getElement().toBlob(\r\n        (data: Blob) => {\r\n          this.save.emit(data);\r\n        },\r\n        this.outputMimeType,\r\n        this.outputQuality\r\n      );\r\n    }\r\n  }\r\n\r\n  public doLoadOriginal() {\r\n    this.loadOriginal.emit();\r\n  }\r\n\r\n  public getTextTranslated(name: string): string {\r\n    let strOk = name.split('.').reduce((o, i) => o[i], this.i18n as any);\r\n\r\n    if (this.i18nUser) {\r\n      try {\r\n        const str = name.split('.').reduce((o, i) => o[i], this.i18nUser as any);\r\n        if (str) {\r\n          strOk = str;\r\n        }\r\n      } catch (e) {\r\n        // if we pass here, ignored\r\n      }\r\n    }\r\n\r\n    if (!strOk) {\r\n      console.error(name + ' translation not found !');\r\n    }\r\n\r\n    return strOk;\r\n  }\r\n\r\n  public getTooltipTranslated(name: string): string {\r\n    if (this.enableTooltip) {\r\n      return this.getTextTranslated(name)\r\n    } else {\r\n      return '';\r\n    }\r\n  }\r\n\r\n  private setUndoRedo() {\r\n    this.canUndo = this.canvas.getObjects().length > 0;\r\n    this.canRedo = this.stack.length > 0;\r\n    // this.canvas.renderAll();\r\n  }\r\n\r\n  public importPhotoFromFile(event: Event | any) {\r\n    if (event.target.files && event.target.files.length > 0) {\r\n      const file = event.target.files[0];\r\n      if (file.type.match('image.*')) {\r\n        this.importPhotoFromBlob(file);\r\n      } else {\r\n        throw new Error('Not an image !');\r\n      }\r\n    }\r\n  }\r\n\r\n  public removeImage() {\r\n    if (this.imageUsed) {\r\n      this.imageUsed.dispose();\r\n      this.imageUsed = null;\r\n    }\r\n    this.canvas.backgroundImage = null;\r\n\r\n    if (this.width && this.height) {\r\n      this.canvas.setWidth(this.width);\r\n      this.canvas.setHeight(this.height);\r\n    }\r\n\r\n    this.canvas.renderAll();\r\n  }\r\n\r\n  public get hasImage(): boolean {\r\n    return !!this.canvas.backgroundImage;\r\n  }\r\n\r\n  private importPhotoFromSrc(src: string) {\r\n    this.isLoading = true;\r\n    let isFirstTry = true;\r\n    const imgEl = new Image();\r\n    imgEl.setAttribute('crossOrigin', 'anonymous');\r\n    imgEl.src = src;\r\n    imgEl.onerror = () => {\r\n      // Retry with cors proxy\r\n      if (isFirstTry) {\r\n        imgEl.src = 'https://cors-anywhere.herokuapp.com/' + this.src;\r\n        isFirstTry = false;\r\n      } else {\r\n        this.isLoading = false;\r\n        this.hasError = true;\r\n        this.errorMessage = this.getTextTranslated('loadError').replace('%@', this.src as string);\r\n      }\r\n    };\r\n    imgEl.onload = () => {\r\n      this.isLoading = false;\r\n      this.imageUsed = new fabric.Image(imgEl);\r\n\r\n      this.imageUsed.cloneAsImage(image => {\r\n        let width = imgEl.width;\r\n        let height = imgEl.height;\r\n\r\n        if (this.width) {\r\n          width = this.width;\r\n        }\r\n        if (this.height) {\r\n          height = this.height;\r\n        }\r\n\r\n        image.scaleToWidth(width, false);\r\n        image.scaleToHeight(height, false);\r\n\r\n        this.canvas.setBackgroundImage(image, ((img: HTMLImageElement) => {\r\n          if (img) {\r\n            if (this.forceSizeCanvas) {\r\n              this.canvas.setWidth(width);\r\n              this.canvas.setHeight(height);\r\n            } else {\r\n              this.canvas.setWidth(image.getScaledWidth());\r\n              this.canvas.setHeight(image.getScaledHeight());\r\n            }\r\n          }\r\n        }), {\r\n          crossOrigin: 'anonymous',\r\n          originX: 'left',\r\n          originY: 'top'\r\n        });\r\n      });\r\n    };\r\n  }\r\n\r\n  private importPhotoFromBlob(file: Blob | File) {\r\n    const reader = new FileReader();\r\n    reader.readAsDataURL(file);\r\n    reader.onload = (evtReader: any) => {\r\n      if (evtReader.target.readyState == FileReader.DONE) {\r\n        this.importPhotoFromSrc(evtReader.target.result);\r\n      }\r\n    };\r\n  }\r\n\r\n  public importPhotoFromUrl() {\r\n    const url = prompt(this.getTooltipTranslated('loadImageUrl'));\r\n    if (url) {\r\n      this.importPhotoFromSrc(url);\r\n    }\r\n  }\r\n\r\n  public close(){\r\n    this.closeDialog.emit();\r\n  }\r\n}\r\n","<div class=\"loading\" *ngIf=\"isLoading && loadingTemplate\">\r\n  <ng-container *ngTemplateOutlet=\"loadingTemplate\"></ng-container>\r\n</div>\r\n<div class=\"error\" *ngIf=\"hasError\">\r\n  <ng-container *ngTemplateOutlet=\"errorTemplate ? errorTemplate : defaultError\"></ng-container>\r\n</div>\r\n\r\n<!-- <ng-template #defaultLoading>\r\n    <p>{{ getTextTranslated('loading') }}</p>\r\n</ng-template> -->\r\n<ng-template #defaultError>\r\n  <p>{{ errorMessage }}</p>\r\n</ng-template>\r\n\r\n<div class=\"toolbar\" *ngIf=\"!isLoading\">\r\n  <div class=\"tools\">\r\n\r\n      <div class=\"brush\">\r\n          <i class=\"title\">tools</i>\r\n          <div class=\"internal\">\r\n            <i class=\"material-icons btn\" [class.selected]=\"currentTool == 'brush'\" (click)=\"selectTool('brush')\"\r\n              [title]=\"getTooltipTranslated('tools.brush')\"><mat-icon>brush</mat-icon></i>\r\n            <span *ngFor=\"let drawingSizeName of drawingSizesName\" class=\"size btn mr-1\"\r\n              [style.width.px]=\"drawingSizes[drawingSizeName] * 0.8 + 8\"\r\n              [style.height.px]=\"drawingSizes[drawingSizeName] * 0.8 + 8\"\r\n              [style.borderRadius.px]=\"drawingSizes[drawingSizeName] * 0.4 + 4\"\r\n              [class.selected]=\"currentSize == drawingSizeName\" [title]=\"getTooltipTranslated('sizes.' + drawingSizeName)\"\r\n              (click)=\"selectDrawingSize(drawingSizeName)\">\r\n            </span>\r\n          </div>\r\n      </div>\r\n\r\n      <div class=\"commands\">\r\n        <i class=\"title\">options</i>\r\n        <div class=\"internal\">\r\n          <i class=\"material-icons btn\" [class.disabled]=\"!canUndo\" (click)=\"undo()\"\r\n          [title]=\"getTooltipTranslated('undo')\"><mat-icon>undo</mat-icon></i>\r\n          <i class=\"material-icons btn\" [class.disabled]=\"!canRedo\" (click)=\"redo()\"\r\n            [title]=\"getTooltipTranslated('redo')\"><mat-icon>redo</mat-icon></i>\r\n          <i class=\"material-icons btn\" (click)=\"clearCanvas()\" [title]=\"getTooltipTranslated('clear')\"><mat-icon>clear</mat-icon></i>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"colors\">\r\n        <i class=\"title\">colors</i>\r\n        <div class=\"internal\">\r\n          <div *ngFor=\"let colorName of colorsName\" [class.selected]=\"currentColor == colorName\" class=\"color\"\r\n          [ngClass]=\"colorName\" [style.background]=\"colors[colorName]\"\r\n          [title]=\"getTooltipTranslated('colors.' + colorName)\" (click)=\"selectColor(colorName)\">\r\n          </div>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"actions\">\r\n        <i class=\"title\">actions</i>\r\n        <div class=\"internal\">\r\n          <a href=\"#\" class=\"btn btn-success\" (click)=\"saveImage(); $event.preventDefault()\" *ngIf=\"!inConfig\">{{\r\n            getTextTranslated('saveBtn') }}</a>\r\n          <a href=\"#\" class=\"btn btn-warning\" *ngIf=\"showCancelButton && !inConfig\" (click)=\"doLoadOriginal(); $event.preventDefault()\">{{\r\n            getTextTranslated('cancelBtn') }}</a>\r\n          <a href=\"#\" class=\"btn btn-danger\" *ngIf=\"showCancelButton\" (click)=\"close(); $event.preventDefault()\">{{\r\n            getTextTranslated('closeDialog') }}</a>\r\n          </div>\r\n      </div>\r\n\r\n  </div>\r\n\r\n  <!-- Any additional toolbar buttons to be projected by the consuming app -->\r\n  <ng-content></ng-content>\r\n</div>\r\n\r\n<div [ngStyle]=\"{ border: borderCss }\">\r\n  <canvas [id]=\"componentGuid\"></canvas>\r\n</div>"]}
@@ -47,6 +47,7 @@ import { ImageFieldSelectorTemplateComponent } from './components/private/field-
47
47
  import { LabelFieldTemplateComponent } from './components/private/field-templates/label-field-template/label-field-template.component';
48
48
  import { ImageSelectorFilterTemplateComponent } from './components/private/form-statistics/filter-templates/image-selector-filter-template/image-selector-filter-template.component';
49
49
  import { EqpImgDrawingModule } from '@eqproject/eqp-img-drawing';
50
+ import { TmwImageDrawerComponent } from './components/private/tmw-image-drawer/tmw-image-drawer.component';
50
51
  import * as i0 from "@angular/core";
51
52
  import * as i1 from "@eqproject/eqp-numeric";
52
53
  export const customNumericMaskConfig = {
@@ -103,7 +104,8 @@ EqpDynamicModuleModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0",
103
104
  GraphComponent,
104
105
  ImageFieldSelectorTemplateComponent,
105
106
  LabelFieldTemplateComponent,
106
- ImageSelectorFilterTemplateComponent], imports: [MaterialModule,
107
+ ImageSelectorFilterTemplateComponent,
108
+ TmwImageDrawerComponent], imports: [MaterialModule,
107
109
  FormsModule,
108
110
  CommonModule,
109
111
  ReactiveFormsModule,
@@ -169,7 +171,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
169
171
  GraphComponent,
170
172
  ImageFieldSelectorTemplateComponent,
171
173
  LabelFieldTemplateComponent,
172
- ImageSelectorFilterTemplateComponent
174
+ ImageSelectorFilterTemplateComponent,
175
+ TmwImageDrawerComponent
173
176
  ],
174
177
  imports: [
175
178
  MaterialModule,
@@ -193,4 +196,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
193
196
  ]
194
197
  }]
195
198
  }] });
196
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eqp-dynamic-module.module.js","sourceRoot":"","sources":["../../../../projects/eqp-dynamic-module/src/lib/eqp-dynamic-module.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { NgModule } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { EqpDynamicModuleComponent } from './components/exported/eqp-dynamic-module/eqp-dynamic-module.component';\r\nimport { MaterialModule } from './modules/material.module';\r\nimport { EqpTableModule } from '@eqproject/eqp-table';\r\nimport { EqpAttachmentsModule } from '@eqproject/eqp-attachments';\r\nimport { EqpSelectModule } from '@eqproject/eqp-select';\r\nimport { EqpDatetimepickerModule } from '@eqproject/eqp-datetimepicker';\r\nimport { EqpFiltersModule } from '@eqproject/eqp-filters';\r\nimport { EqpNumericInputMode, EqpNumericModule } from '@eqproject/eqp-numeric';\r\nimport { EqpDynamicModuleConfiguratorComponent } from './components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component';\r\nimport { AddFormFieldComponent } from './components/private/add-form-field/add-form-field.component';\r\nimport { TextFieldTemplateComponent } from './components/private/field-templates/text-field-template/text-field-template.component';\r\nimport { BooleanFieldTemplateComponent } from './components/private/field-templates/boolean-field-template/boolean-field-template.component';\r\nimport { DateFieldTemplateComponent } from './components/private/field-templates/date-field-template/date-field-template.component';\r\nimport { TextareaFieldTemplateComponent } from './components/private/field-templates/textarea-field-template/textarea-field-template.component';\r\nimport { NumericFieldTemplateComponent } from './components/private/field-templates/numeric-field-template/numeric-field-template.component';\r\nimport { ListValueFieldTemplateComponent } from './components/private/field-templates/list-value-field-template/list-value-field-template.component';\r\nimport { AttachmentFieldTemplateComponent } from './components/private/field-templates/attachment-field-template/attachment-field-template.component';\r\nimport { ImageFieldTemplateComponent } from './components/private/field-templates/image-field-template/image-field-template.component';\r\nimport { ListFormRecordComponent } from './components/private/form-records/list-form-record/list-form-record.component';\r\nimport { AddFormRecordComponent } from './components/private/form-records/add-form-record/add-form-record.component';\r\nimport { DynamicModuleFieldComponent } from './components/private/dynamic-module-field/dynamic-module-field.component';\r\nimport { SpinnerComponent } from './components/private/spinner/spinner.component';\r\nimport { DynamicModuleFieldFixComponent } from './components/private/dynamic-module-field-fix/dynamic-module-field.component';\r\nimport { AddFormulaComponent,DialogDataExampleDialog } from './components/private/add-formula-field/add-formula-field.component';\r\nimport { RepairFormFieldsComponent } from './components/private/form-records/repair-form-fields/repair-form-fields.component';\r\nimport { ListViewFormRecordComponent } from './components/private/form-records/list-view-form-record/list-view-form-record.component';\r\nimport { ViewFormRecordComponent } from './components/private/form-records/view-form-record/view-form-record.component';\r\nimport { SingleRecordComponent } from './components/private/form-records/list-view-form-record/single-record/single-record.component';\r\nimport { FilterFormStatisticComponent } from './components/private/form-statistics/filter-form-statistic/filter-form-statistic.component';\r\nimport { DynamicModuleFilterFixComponent } from './components/private/form-statistics/dynamic-module-filter-fix/dynamic-module-filter-fix.component';\r\nimport { TextFilterTemplateComponent } from './components/private/form-statistics/filter-templates/text-filter-template/text-filter-template.component';\r\nimport { NumericFilterTemplateComponent } from './components/private/form-statistics/filter-templates/numeric-filter-template/numeric-filter-template.component';\r\nimport { BooleanFilterTemplateComponent } from './components/private/form-statistics/filter-templates/boolean-filter-template/boolean-filter-template.component';\r\nimport { DateFilterTemplateComponent } from './components/private/form-statistics/filter-templates/date-filter-template/date-filter-template.component';\r\nimport { ListValueFilterTemplateComponent } from './components/private/form-statistics/filter-templates/list-value-filter-template/list-value-filter-template.component';\r\nimport { TextareaFilterTemplateComponent } from './components/private/form-statistics/filter-templates/textarea-filter-template/textarea-filter-template.component';\r\nimport { AttachmentFilterTemplateComponent } from './components/private/form-statistics/filter-templates/attachment-filter-template/attachment-filter-template.component';\r\nimport { ImageFilterTemplateComponent } from './components/private/form-statistics/filter-templates/image-filter-template/image-filter-template.component';\r\nimport { ListFormRecordFilterTemplateComponent } from './components/private/form-statistics/filter-templates/list-form-record-filter-template/list-form-record-filter-template.component';\r\nimport { GraphsComponent } from './components/private/graphs/graphs.component';\r\nimport { GraphComponent } from './components/private/graphs/graph/graph.component';\r\nimport { CanvasJSAngularStockChartsModule, CanvasJSChart, CanvasJSStockChart } from '@canvasjs/angular-stockcharts';\r\nimport { ImageFieldSelectorTemplateComponent } from './components/private/field-templates/image-field-selector-template/image-field-selector-template.component';\r\nimport { LabelFieldTemplateComponent } from './components/private/field-templates/label-field-template/label-field-template.component';\r\nimport { ImageSelectorFilterTemplateComponent } from './components/private/form-statistics/filter-templates/image-selector-filter-template/image-selector-filter-template.component';\r\nimport { EqpImgDrawingModule } from '@eqproject/eqp-img-drawing';\r\n\r\nexport const customNumericMaskConfig = {\r\n  align: \"right\",\r\n  allowNegative: true,\r\n  allowZero: true,\r\n  decimal: \"\",\r\n  precision: 0,\r\n  prefix: \"\",\r\n  suffix: \"\",\r\n  thousands: \"\",\r\n  nullable: true,\r\n  min: null,\r\n  max: null,\r\n  inputMode: EqpNumericInputMode.FINANCIAL,\r\n};\r\n\r\n@NgModule({\r\n  declarations: [\r\n    EqpDynamicModuleComponent,\r\n    EqpDynamicModuleConfiguratorComponent,\r\n    AddFormFieldComponent,\r\n    TextFieldTemplateComponent,\r\n    BooleanFieldTemplateComponent,\r\n    DateFieldTemplateComponent,\r\n    TextareaFieldTemplateComponent,\r\n    NumericFieldTemplateComponent,\r\n    ListValueFieldTemplateComponent,\r\n    AttachmentFieldTemplateComponent,\r\n    ImageFieldTemplateComponent,\r\n    ListFormRecordComponent,\r\n    ListViewFormRecordComponent,\r\n    AddFormRecordComponent,\r\n    ViewFormRecordComponent,\r\n    DynamicModuleFieldComponent,\r\n    DynamicModuleFieldFixComponent,\r\n    SpinnerComponent,\r\n    AddFormulaComponent,\r\n    DialogDataExampleDialog,\r\n    RepairFormFieldsComponent,\r\n    SingleRecordComponent,\r\n    FilterFormStatisticComponent,\r\n    DynamicModuleFilterFixComponent,\r\n    TextFilterTemplateComponent,\r\n    NumericFilterTemplateComponent,\r\n    BooleanFilterTemplateComponent,\r\n    DateFilterTemplateComponent,\r\n    ListValueFilterTemplateComponent,\r\n    TextareaFilterTemplateComponent,\r\n    AttachmentFilterTemplateComponent,\r\n    ImageFilterTemplateComponent,\r\n    ListFormRecordFilterTemplateComponent,\r\n    GraphsComponent,\r\n    GraphComponent,\r\n    ImageFieldSelectorTemplateComponent,\r\n    LabelFieldTemplateComponent,\r\n    ImageSelectorFilterTemplateComponent\r\n  ],\r\n  imports: [\r\n    MaterialModule,\r\n    FormsModule,\r\n    CommonModule,\r\n    ReactiveFormsModule,\r\n    EqpTableModule,\r\n    EqpAttachmentsModule,\r\n    EqpSelectModule,\r\n    EqpDatetimepickerModule,\r\n    EqpFiltersModule,\r\n    EqpImgDrawingModule,\r\n    EqpNumericModule.forRoot(customNumericMaskConfig),\r\n    CanvasJSAngularStockChartsModule\r\n  ],\r\n  exports: [\r\n    EqpDynamicModuleComponent,\r\n    EqpDynamicModuleConfiguratorComponent,\r\n    CanvasJSChart,\r\n    CanvasJSStockChart\r\n  ]\r\n})\r\nexport class EqpDynamicModuleModule { }\r\n"]}
199
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eqp-dynamic-module.module.js","sourceRoot":"","sources":["../../../../projects/eqp-dynamic-module/src/lib/eqp-dynamic-module.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { NgModule } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { EqpDynamicModuleComponent } from './components/exported/eqp-dynamic-module/eqp-dynamic-module.component';\r\nimport { MaterialModule } from './modules/material.module';\r\nimport { EqpTableModule } from '@eqproject/eqp-table';\r\nimport { EqpAttachmentsModule } from '@eqproject/eqp-attachments';\r\nimport { EqpSelectModule } from '@eqproject/eqp-select';\r\nimport { EqpDatetimepickerModule } from '@eqproject/eqp-datetimepicker';\r\nimport { EqpFiltersModule } from '@eqproject/eqp-filters';\r\nimport { EqpNumericInputMode, EqpNumericModule } from '@eqproject/eqp-numeric';\r\nimport { EqpDynamicModuleConfiguratorComponent } from './components/exported/eqp-dynamic-module-configurator/eqp-dynamic-module-configurator.component';\r\nimport { AddFormFieldComponent } from './components/private/add-form-field/add-form-field.component';\r\nimport { TextFieldTemplateComponent } from './components/private/field-templates/text-field-template/text-field-template.component';\r\nimport { BooleanFieldTemplateComponent } from './components/private/field-templates/boolean-field-template/boolean-field-template.component';\r\nimport { DateFieldTemplateComponent } from './components/private/field-templates/date-field-template/date-field-template.component';\r\nimport { TextareaFieldTemplateComponent } from './components/private/field-templates/textarea-field-template/textarea-field-template.component';\r\nimport { NumericFieldTemplateComponent } from './components/private/field-templates/numeric-field-template/numeric-field-template.component';\r\nimport { ListValueFieldTemplateComponent } from './components/private/field-templates/list-value-field-template/list-value-field-template.component';\r\nimport { AttachmentFieldTemplateComponent } from './components/private/field-templates/attachment-field-template/attachment-field-template.component';\r\nimport { ImageFieldTemplateComponent } from './components/private/field-templates/image-field-template/image-field-template.component';\r\nimport { ListFormRecordComponent } from './components/private/form-records/list-form-record/list-form-record.component';\r\nimport { AddFormRecordComponent } from './components/private/form-records/add-form-record/add-form-record.component';\r\nimport { DynamicModuleFieldComponent } from './components/private/dynamic-module-field/dynamic-module-field.component';\r\nimport { SpinnerComponent } from './components/private/spinner/spinner.component';\r\nimport { DynamicModuleFieldFixComponent } from './components/private/dynamic-module-field-fix/dynamic-module-field.component';\r\nimport { AddFormulaComponent,DialogDataExampleDialog } from './components/private/add-formula-field/add-formula-field.component';\r\nimport { RepairFormFieldsComponent } from './components/private/form-records/repair-form-fields/repair-form-fields.component';\r\nimport { ListViewFormRecordComponent } from './components/private/form-records/list-view-form-record/list-view-form-record.component';\r\nimport { ViewFormRecordComponent } from './components/private/form-records/view-form-record/view-form-record.component';\r\nimport { SingleRecordComponent } from './components/private/form-records/list-view-form-record/single-record/single-record.component';\r\nimport { FilterFormStatisticComponent } from './components/private/form-statistics/filter-form-statistic/filter-form-statistic.component';\r\nimport { DynamicModuleFilterFixComponent } from './components/private/form-statistics/dynamic-module-filter-fix/dynamic-module-filter-fix.component';\r\nimport { TextFilterTemplateComponent } from './components/private/form-statistics/filter-templates/text-filter-template/text-filter-template.component';\r\nimport { NumericFilterTemplateComponent } from './components/private/form-statistics/filter-templates/numeric-filter-template/numeric-filter-template.component';\r\nimport { BooleanFilterTemplateComponent } from './components/private/form-statistics/filter-templates/boolean-filter-template/boolean-filter-template.component';\r\nimport { DateFilterTemplateComponent } from './components/private/form-statistics/filter-templates/date-filter-template/date-filter-template.component';\r\nimport { ListValueFilterTemplateComponent } from './components/private/form-statistics/filter-templates/list-value-filter-template/list-value-filter-template.component';\r\nimport { TextareaFilterTemplateComponent } from './components/private/form-statistics/filter-templates/textarea-filter-template/textarea-filter-template.component';\r\nimport { AttachmentFilterTemplateComponent } from './components/private/form-statistics/filter-templates/attachment-filter-template/attachment-filter-template.component';\r\nimport { ImageFilterTemplateComponent } from './components/private/form-statistics/filter-templates/image-filter-template/image-filter-template.component';\r\nimport { ListFormRecordFilterTemplateComponent } from './components/private/form-statistics/filter-templates/list-form-record-filter-template/list-form-record-filter-template.component';\r\nimport { GraphsComponent } from './components/private/graphs/graphs.component';\r\nimport { GraphComponent } from './components/private/graphs/graph/graph.component';\r\nimport { CanvasJSAngularStockChartsModule, CanvasJSChart, CanvasJSStockChart } from '@canvasjs/angular-stockcharts';\r\nimport { ImageFieldSelectorTemplateComponent } from './components/private/field-templates/image-field-selector-template/image-field-selector-template.component';\r\nimport { LabelFieldTemplateComponent } from './components/private/field-templates/label-field-template/label-field-template.component';\r\nimport { ImageSelectorFilterTemplateComponent } from './components/private/form-statistics/filter-templates/image-selector-filter-template/image-selector-filter-template.component';\r\nimport { EqpImgDrawingModule } from '@eqproject/eqp-img-drawing';\r\nimport { TmwImageDrawerComponent } from './components/private/tmw-image-drawer/tmw-image-drawer.component';\r\n\r\nexport const customNumericMaskConfig = {\r\n  align: \"right\",\r\n  allowNegative: true,\r\n  allowZero: true,\r\n  decimal: \"\",\r\n  precision: 0,\r\n  prefix: \"\",\r\n  suffix: \"\",\r\n  thousands: \"\",\r\n  nullable: true,\r\n  min: null,\r\n  max: null,\r\n  inputMode: EqpNumericInputMode.FINANCIAL,\r\n};\r\n\r\n@NgModule({\r\n  declarations: [\r\n    EqpDynamicModuleComponent,\r\n    EqpDynamicModuleConfiguratorComponent,\r\n    AddFormFieldComponent,\r\n    TextFieldTemplateComponent,\r\n    BooleanFieldTemplateComponent,\r\n    DateFieldTemplateComponent,\r\n    TextareaFieldTemplateComponent,\r\n    NumericFieldTemplateComponent,\r\n    ListValueFieldTemplateComponent,\r\n    AttachmentFieldTemplateComponent,\r\n    ImageFieldTemplateComponent,\r\n    ListFormRecordComponent,\r\n    ListViewFormRecordComponent,\r\n    AddFormRecordComponent,\r\n    ViewFormRecordComponent,\r\n    DynamicModuleFieldComponent,\r\n    DynamicModuleFieldFixComponent,\r\n    SpinnerComponent,\r\n    AddFormulaComponent,\r\n    DialogDataExampleDialog,\r\n    RepairFormFieldsComponent,\r\n    SingleRecordComponent,\r\n    FilterFormStatisticComponent,\r\n    DynamicModuleFilterFixComponent,\r\n    TextFilterTemplateComponent,\r\n    NumericFilterTemplateComponent,\r\n    BooleanFilterTemplateComponent,\r\n    DateFilterTemplateComponent,\r\n    ListValueFilterTemplateComponent,\r\n    TextareaFilterTemplateComponent,\r\n    AttachmentFilterTemplateComponent,\r\n    ImageFilterTemplateComponent,\r\n    ListFormRecordFilterTemplateComponent,\r\n    GraphsComponent,\r\n    GraphComponent,\r\n    ImageFieldSelectorTemplateComponent,\r\n    LabelFieldTemplateComponent,\r\n    ImageSelectorFilterTemplateComponent,\r\n    TmwImageDrawerComponent\r\n  ],\r\n  imports: [\r\n    MaterialModule,\r\n    FormsModule,\r\n    CommonModule,\r\n    ReactiveFormsModule,\r\n    EqpTableModule,\r\n    EqpAttachmentsModule,\r\n    EqpSelectModule,\r\n    EqpDatetimepickerModule,\r\n    EqpFiltersModule,\r\n    EqpImgDrawingModule,\r\n    EqpNumericModule.forRoot(customNumericMaskConfig),\r\n    CanvasJSAngularStockChartsModule\r\n  ],\r\n  exports: [\r\n    EqpDynamicModuleComponent,\r\n    EqpDynamicModuleConfiguratorComponent,\r\n    CanvasJSChart,\r\n    CanvasJSStockChart\r\n  ]\r\n})\r\nexport class EqpDynamicModuleModule { }\r\n"]}