@acorex/components 19.10.10 → 19.10.11

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 (153) hide show
  1. package/autocomplete/README.md +3 -0
  2. package/autocomplete/index.d.ts +2 -0
  3. package/autocomplete/lib/autocomplete.component.d.ts +113 -0
  4. package/autocomplete/lib/autocomplete.module.d.ts +7 -0
  5. package/common/lib/classes/components.class.d.ts +14 -1
  6. package/common/lib/classes/datasource.class.d.ts +2 -2
  7. package/data-table/lib/columns/row-select-column.component.d.ts +8 -7
  8. package/dropdown/lib/dropdown-box.component.d.ts +2 -1
  9. package/dropdown/lib/dropdown-panel.component.d.ts +3 -1
  10. package/dropdown-button/lib/dropdown-button.component.d.ts +2 -1
  11. package/fesm2022/acorex-components-action-sheet.mjs +11 -11
  12. package/fesm2022/acorex-components-alert.mjs +8 -8
  13. package/fesm2022/acorex-components-audio-wave.mjs +8 -8
  14. package/fesm2022/acorex-components-autocomplete.mjs +317 -0
  15. package/fesm2022/acorex-components-autocomplete.mjs.map +1 -0
  16. package/fesm2022/acorex-components-avatar.mjs +11 -11
  17. package/fesm2022/acorex-components-badge.mjs +8 -8
  18. package/fesm2022/acorex-components-bottom-navigation.mjs +11 -11
  19. package/fesm2022/acorex-components-breadcrumbs.mjs +11 -11
  20. package/fesm2022/acorex-components-button-group.mjs +11 -11
  21. package/fesm2022/acorex-components-button.mjs +15 -15
  22. package/fesm2022/acorex-components-calendar.mjs +15 -15
  23. package/fesm2022/acorex-components-check-box.mjs +11 -11
  24. package/fesm2022/acorex-components-check-box.mjs.map +1 -1
  25. package/fesm2022/acorex-components-chips.mjs +8 -8
  26. package/fesm2022/acorex-components-circular-progress.mjs +8 -8
  27. package/fesm2022/acorex-components-collapse.mjs +12 -12
  28. package/fesm2022/acorex-components-color-box.mjs +10 -10
  29. package/fesm2022/acorex-components-color-box.mjs.map +1 -1
  30. package/fesm2022/acorex-components-color-palette.mjs +26 -26
  31. package/fesm2022/acorex-components-comment.mjs +29 -29
  32. package/fesm2022/acorex-components-common.mjs +736 -696
  33. package/fesm2022/acorex-components-common.mjs.map +1 -1
  34. package/fesm2022/acorex-components-conversation.mjs +52 -52
  35. package/fesm2022/acorex-components-conversation.mjs.map +1 -1
  36. package/fesm2022/acorex-components-cron-job.mjs +47 -47
  37. package/fesm2022/acorex-components-data-pager.mjs +44 -47
  38. package/fesm2022/acorex-components-data-pager.mjs.map +1 -1
  39. package/fesm2022/acorex-components-data-table.mjs +91 -68
  40. package/fesm2022/acorex-components-data-table.mjs.map +1 -1
  41. package/fesm2022/acorex-components-datetime-box.mjs +10 -10
  42. package/fesm2022/acorex-components-datetime-box.mjs.map +1 -1
  43. package/fesm2022/acorex-components-datetime-input.mjs +9 -9
  44. package/fesm2022/acorex-components-datetime-picker.mjs +9 -9
  45. package/fesm2022/acorex-components-decorators.mjs +26 -26
  46. package/fesm2022/acorex-components-dialog.mjs +12 -12
  47. package/fesm2022/acorex-components-drawer.mjs +14 -14
  48. package/fesm2022/acorex-components-dropdown-button.mjs +16 -10
  49. package/fesm2022/acorex-components-dropdown-button.mjs.map +1 -1
  50. package/fesm2022/acorex-components-dropdown.mjs +23 -15
  51. package/fesm2022/acorex-components-dropdown.mjs.map +1 -1
  52. package/fesm2022/acorex-components-file-explorer.mjs +27 -27
  53. package/fesm2022/acorex-components-file-explorer.mjs.map +1 -1
  54. package/fesm2022/acorex-components-form.mjs +17 -17
  55. package/fesm2022/acorex-components-grid-layout-builder.mjs +149 -598
  56. package/fesm2022/acorex-components-grid-layout-builder.mjs.map +1 -1
  57. package/fesm2022/acorex-components-image-editor.mjs +311 -180
  58. package/fesm2022/acorex-components-image-editor.mjs.map +1 -1
  59. package/fesm2022/acorex-components-image.mjs +8 -8
  60. package/fesm2022/acorex-components-json-viewer.mjs +8 -8
  61. package/fesm2022/acorex-components-kbd.mjs +11 -11
  62. package/fesm2022/acorex-components-label.mjs +8 -8
  63. package/fesm2022/acorex-components-list.mjs +9 -9
  64. package/fesm2022/acorex-components-loading-dialog.mjs +11 -11
  65. package/fesm2022/acorex-components-loading.mjs +18 -18
  66. package/fesm2022/acorex-components-loading.mjs.map +1 -1
  67. package/fesm2022/acorex-components-map.mjs +17 -27
  68. package/fesm2022/acorex-components-map.mjs.map +1 -1
  69. package/fesm2022/acorex-components-media-viewer.mjs +36 -36
  70. package/fesm2022/acorex-components-media-viewer.mjs.map +1 -1
  71. package/fesm2022/acorex-components-menu.mjs +17 -17
  72. package/fesm2022/acorex-components-navbar.mjs +8 -8
  73. package/fesm2022/acorex-components-notification.mjs +11 -11
  74. package/fesm2022/acorex-components-number-box.mjs +9 -9
  75. package/fesm2022/acorex-components-otp.mjs +9 -9
  76. package/fesm2022/acorex-components-page.mjs +11 -11
  77. package/fesm2022/acorex-components-paint.mjs +20 -20
  78. package/fesm2022/acorex-components-password-box.mjs +12 -12
  79. package/fesm2022/acorex-components-pdf-reader.mjs +8 -8
  80. package/fesm2022/acorex-components-phone-box.mjs +9 -9
  81. package/fesm2022/acorex-components-picker.mjs +14 -14
  82. package/fesm2022/acorex-components-popover.mjs +8 -8
  83. package/fesm2022/acorex-components-popup.mjs +11 -11
  84. package/fesm2022/acorex-components-progress-bar.mjs +8 -8
  85. package/fesm2022/acorex-components-qrcode.mjs +8 -8
  86. package/fesm2022/acorex-components-query-builder.mjs +25 -14
  87. package/fesm2022/acorex-components-query-builder.mjs.map +1 -1
  88. package/fesm2022/acorex-components-radio.mjs +9 -9
  89. package/fesm2022/acorex-components-rail-navigation.mjs +14 -14
  90. package/fesm2022/acorex-components-range-slider.mjs +8 -8
  91. package/fesm2022/acorex-components-rate-picker.mjs +8 -8
  92. package/fesm2022/acorex-components-rest-api-generator.mjs +23 -23
  93. package/fesm2022/acorex-components-result.mjs +8 -8
  94. package/fesm2022/acorex-components-routing-progress.mjs +8 -8
  95. package/fesm2022/acorex-components-scheduler.mjs +14 -14
  96. package/fesm2022/acorex-components-scheduler.mjs.map +1 -1
  97. package/fesm2022/acorex-components-scss.mjs +4 -4
  98. package/fesm2022/acorex-components-search-box.mjs +10 -10
  99. package/fesm2022/acorex-components-select-box.mjs +10 -10
  100. package/fesm2022/acorex-components-select-box.mjs.map +1 -1
  101. package/fesm2022/acorex-components-selection-list.mjs +9 -9
  102. package/fesm2022/acorex-components-side-menu.mjs +15 -15
  103. package/fesm2022/acorex-components-skeleton.mjs +8 -8
  104. package/fesm2022/acorex-components-slider.mjs +9 -9
  105. package/fesm2022/acorex-components-sliding-item.mjs +14 -14
  106. package/fesm2022/acorex-components-step-wizard.mjs +14 -14
  107. package/fesm2022/acorex-components-switch.mjs +11 -11
  108. package/fesm2022/acorex-components-tabs.mjs +14 -14
  109. package/fesm2022/acorex-components-tag-box.mjs +121 -0
  110. package/fesm2022/acorex-components-tag-box.mjs.map +1 -0
  111. package/fesm2022/acorex-components-tag.mjs +9 -9
  112. package/fesm2022/acorex-components-tag.mjs.map +1 -1
  113. package/fesm2022/acorex-components-text-area.mjs +9 -9
  114. package/fesm2022/acorex-components-text-box.mjs +14 -14
  115. package/fesm2022/acorex-components-text-box.mjs.map +1 -1
  116. package/fesm2022/acorex-components-time-line.mjs +12 -12
  117. package/fesm2022/acorex-components-toast.mjs +11 -11
  118. package/fesm2022/acorex-components-toolbar.mjs +8 -8
  119. package/fesm2022/acorex-components-tooltip.mjs +11 -11
  120. package/fesm2022/acorex-components-tree-view.mjs +31 -27
  121. package/fesm2022/acorex-components-tree-view.mjs.map +1 -1
  122. package/fesm2022/acorex-components-uploader.mjs +32 -27
  123. package/fesm2022/acorex-components-uploader.mjs.map +1 -1
  124. package/fesm2022/acorex-components-video-player.mjs +8 -8
  125. package/fesm2022/acorex-components-wysiwyg.mjs +32 -32
  126. package/grid-layout-builder/index.d.ts +0 -1
  127. package/grid-layout-builder/lib/grid-layout-builder.module.d.ts +1 -2
  128. package/grid-layout-builder/lib/grid-layout-container.component.d.ts +37 -235
  129. package/grid-layout-builder/lib/grid-layout-widget.component.d.ts +6 -86
  130. package/grid-layout-builder/lib/types.d.ts +8 -12
  131. package/image-editor/index.d.ts +7 -2
  132. package/image-editor/lib/image-editor-container/image-editor-container.component.d.ts +4 -1
  133. package/image-editor/lib/image-editor-tools/image-editor-crop/image-editor-crop.component.d.ts +3 -8
  134. package/image-editor/lib/image-editor-tools/image-editor-header/image-editor-header.component.d.ts +12 -0
  135. package/image-editor/lib/image-editor-tools/image-editor-highlight/image-editor-highlight.component.d.ts +18 -0
  136. package/image-editor/lib/image-editor-tools/image-editor-history/image-editor-history.component.d.ts +13 -0
  137. package/image-editor/lib/image-editor-tools/image-editor-pen/image-editor-pen.component.d.ts +18 -0
  138. package/image-editor/lib/image-editor-tools/image-editor-rotate/image-editor-rotate.component.d.ts +16 -0
  139. package/image-editor/lib/image-editor-tools/image-editor-tool-selector/image-editor-tool-selector.component.d.ts +12 -0
  140. package/image-editor/lib/image-editor-view/image-editor-view.component.d.ts +7 -1
  141. package/image-editor/lib/image-editor.module.d.ts +10 -6
  142. package/image-editor/lib/image-editor.service.d.ts +6 -10
  143. package/package.json +13 -5
  144. package/query-builder/lib/query-builder.component.d.ts +5 -2
  145. package/tag-box/README.md +3 -0
  146. package/tag-box/index.d.ts +2 -0
  147. package/tag-box/lib/tag-box.component.d.ts +30 -0
  148. package/tag-box/lib/tag-box.module.d.ts +7 -0
  149. package/tree-view/lib/tree-view-item.component.d.ts +3 -2
  150. package/tree-view/lib/tree-view.component.d.ts +6 -7
  151. package/grid-layout-builder/lib/grid-layout-widget.directive.d.ts +0 -106
  152. package/image-editor/lib/image-editor-tools/image-editor-color-picker/image-editor-color-picker.component.d.ts +0 -17
  153. package/image-editor/lib/image-editor-tools/image-editor-pen-mode-changer/image-editor-pen-mode-changer.component.d.ts +0 -34
@@ -1,143 +1,168 @@
1
- import { MXInputBaseValueComponent, MXLookComponent, AXComponent, AXFocusableComponent, AXClearableComponent, AXValuableComponent, MXBaseComponent } from '@acorex/components/common';
1
+ import { AXButtonComponent, AXButtonModule } from '@acorex/components/button';
2
+ import { MXBaseComponent, MXInputBaseValueComponent, MXLookComponent, AXComponent, AXFocusableComponent, AXClearableComponent, AXValuableComponent } from '@acorex/components/common';
3
+ import * as i1 from '@acorex/components/decorators';
4
+ import { AXDecoratorModule, AXDecoratorIconComponent } from '@acorex/components/decorators';
2
5
  import { AXDialogService, AXDialogModule } from '@acorex/components/dialog';
3
6
  import { AXLoadingSpinnerComponent, AXLoadingModule } from '@acorex/components/loading';
7
+ import * as i2 from '@acorex/components/toolbar';
8
+ import { AXToolBarModule } from '@acorex/components/toolbar';
9
+ import { CommonModule } from '@angular/common';
4
10
  import * as i0 from '@angular/core';
5
- import { signal, Injectable, inject, viewChild, forwardRef, Component, ViewEncapsulation, HostBinding, input, Renderer2, computed, NgZone, afterNextRender, effect, ChangeDetectionStrategy, NgModule } from '@angular/core';
6
- import * as i1 from '@angular/forms';
7
- import { NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';
11
+ import { signal, Injectable, inject, output, ViewEncapsulation, Component, ChangeDetectionStrategy, input, viewChild, Renderer2, computed, linkedSignal, NgZone, afterNextRender, effect, HostBinding, contentChild, forwardRef, NgModule } from '@angular/core';
12
+ import * as i1$1 from '@angular/forms';
13
+ import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
8
14
  import { classes } from 'polytype';
9
- import { AXColorBoxComponent, AXColorBoxModule } from '@acorex/components/color-box';
10
15
  import { AXTooltipDirective, AXTooltipModule } from '@acorex/components/tooltip';
11
- import { AXButtonComponent, AXButtonModule } from '@acorex/components/button';
12
- import { AXDecoratorIconComponent, AXDecoratorModule } from '@acorex/components/decorators';
13
- import { AXPopoverComponent, AXPopoverModule } from '@acorex/components/popover';
16
+ import { AXColorBoxComponent, AXColorBoxModule } from '@acorex/components/color-box';
14
17
  import { AXRangeSliderComponent, AXRangeSliderModule } from '@acorex/components/range-slider';
18
+ import { AXPopoverModule } from '@acorex/components/popover';
15
19
  import { AXSelectBoxModule } from '@acorex/components/select-box';
16
20
 
17
21
  class AXImageEditorService {
18
22
  constructor() {
19
- this.penColor = signal('');
20
- this.lineCap = signal('round');
21
- this.lineWidth = signal(10);
22
- this.penType = signal('pen');
23
- this.toggleClear = signal({ state: false, userInteract: false });
24
- this.cropState = signal({ state: false, userInteract: false });
23
+ this.activeToolState = signal(null);
24
+ this.penColor = signal('rgb(12, 12, 12)');
25
+ this.highlightColor = signal('rgb(255, 210, 48)');
26
+ this.penWidth = signal(10);
27
+ this.highlightWidth = signal(10);
28
+ this.penType = signal(null);
25
29
  this.rotate = signal({ state: 0, userInteract: false });
26
30
  this.isImageLoad = signal(false);
27
31
  this.newImage = signal(null);
28
32
  this.initialImage = signal(null);
29
33
  this.imageBlob = signal([]);
34
+ this.undoPressed = signal(false);
35
+ this.redoPressed = signal(false);
30
36
  }
31
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
32
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorService }); }
37
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
38
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorService }); }
33
39
  }
34
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorService, decorators: [{
40
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorService, decorators: [{
35
41
  type: Injectable
36
42
  }] });
37
43
 
38
44
  /**
39
- * paint container.
45
+ * paint mode.
40
46
  * @category Components
41
47
  */
42
- class AXImageEditorContainerComponent extends classes((MXInputBaseValueComponent), MXLookComponent) {
48
+ class AXImageEditorCropComponent {
49
+ constructor() {
50
+ this.service = inject(AXImageEditorService);
51
+ this.cropPressed = output();
52
+ }
53
+ cropButtonHandler() {
54
+ this.cropPressed.emit();
55
+ }
56
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorCropComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
57
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.1.8", type: AXImageEditorCropComponent, isStandalone: true, selector: "ax-image-editor-crop", outputs: { cropPressed: "cropPressed" }, ngImport: i0, template: "<ax-button (click)=\"cropButtonHandler()\" class=\"ax-crop-save ax-sm\" text=\"Crop\"></ax-button>\n", dependencies: [{ kind: "component", type: AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "loadingTextChange"] }], encapsulation: i0.ViewEncapsulation.None }); }
58
+ }
59
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorCropComponent, decorators: [{
60
+ type: Component,
61
+ args: [{ selector: 'ax-image-editor-crop', encapsulation: ViewEncapsulation.None, imports: [AXButtonComponent], template: "<ax-button (click)=\"cropButtonHandler()\" class=\"ax-crop-save ax-sm\" text=\"Crop\"></ax-button>\n" }]
62
+ }] });
63
+
64
+ /**
65
+ * paint mode.
66
+ * @category Components
67
+ */
68
+ class AXImageEditorHistoryComponent {
69
+ constructor() {
70
+ this.service = inject(AXImageEditorService);
71
+ }
72
+ UndoHandler() {
73
+ this.service.undoPressed.set(true);
74
+ }
75
+ RedoHandler() {
76
+ this.service.redoPressed.set(true);
77
+ }
78
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorHistoryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
79
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.1.8", type: AXImageEditorHistoryComponent, isStandalone: true, selector: "ax-image-editor-history", ngImport: i0, template: "<ax-button axTooltip=\"Undo\" axTooltipPlacement=\"top\" (onClick)=\"UndoHandler()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-undo\"></ax-icon>\n</ax-button>\n\n<ax-button axTooltip=\"Redo\" axTooltipPlacement=\"top\" (onClick)=\"RedoHandler()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-redo\"></ax-icon>\n</ax-button>\n", dependencies: [{ kind: "component", type: AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "loadingTextChange"] }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type: i1.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "directive", type: AXTooltipDirective, selector: "[axTooltip]", inputs: ["axTooltip", "axTooltipPlacement", "axTooltipOpenAfter", "axTooltipCloseAfter"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
80
+ }
81
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorHistoryComponent, decorators: [{
82
+ type: Component,
83
+ args: [{ selector: 'ax-image-editor-history', encapsulation: ViewEncapsulation.None, imports: [AXButtonComponent, AXDecoratorModule, AXTooltipDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ax-button axTooltip=\"Undo\" axTooltipPlacement=\"top\" (onClick)=\"UndoHandler()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-undo\"></ax-icon>\n</ax-button>\n\n<ax-button axTooltip=\"Redo\" axTooltipPlacement=\"top\" (onClick)=\"RedoHandler()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-redo\"></ax-icon>\n</ax-button>\n" }]
84
+ }] });
85
+
86
+ /**
87
+ * paint mode.
88
+ * @category Components
89
+ */
90
+ class AXimageEditorHeaderComponent {
91
+ constructor() {
92
+ this.parent = inject(AXImageEditorContainerComponent);
93
+ }
94
+ saveHandler() {
95
+ this.parent.save();
96
+ }
97
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXimageEditorHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
98
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.1.8", type: AXimageEditorHeaderComponent, isStandalone: true, selector: "ax-image-editor-header", ngImport: i0, template: "<ax-toolbar>\n <ax-prefix>\n <ax-image-editor-history></ax-image-editor-history>\n </ax-prefix>\n\n <ax-suffix>\n <ax-button type=\"submit\" (onClick)=\"saveHandler()\" axTooltip=\"Save\" axTooltipPlacement=\"top\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-save\"> </ax-icon>\n </ax-button>\n </ax-suffix>\n</ax-toolbar>\n", styles: ["ax-image-editor-header{width:100%}ax-image-editor-header ax-toolbar{justify-content:space-between}ax-image-editor-header .ax-start-toolbar-divider{display:none}\n"], dependencies: [{ kind: "component", type: AXImageEditorHistoryComponent, selector: "ax-image-editor-history" }, { kind: "component", type: AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "loadingTextChange"] }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type: i1.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i1.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-subtitle, ax-placeholder, ax-overlay" }, { kind: "ngmodule", type: AXToolBarModule }, { kind: "component", type: i2.AXToolBarComponent, selector: "ax-toolbar" }, { kind: "directive", type: AXTooltipDirective, selector: "[axTooltip]", inputs: ["axTooltip", "axTooltipPlacement", "axTooltipOpenAfter", "axTooltipCloseAfter"] }], encapsulation: i0.ViewEncapsulation.None }); }
99
+ }
100
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXimageEditorHeaderComponent, decorators: [{
101
+ type: Component,
102
+ args: [{ selector: 'ax-image-editor-header', encapsulation: ViewEncapsulation.None, imports: [AXImageEditorHistoryComponent, AXButtonComponent, AXDecoratorModule, AXToolBarModule, AXTooltipDirective], template: "<ax-toolbar>\n <ax-prefix>\n <ax-image-editor-history></ax-image-editor-history>\n </ax-prefix>\n\n <ax-suffix>\n <ax-button type=\"submit\" (onClick)=\"saveHandler()\" axTooltip=\"Save\" axTooltipPlacement=\"top\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-save\"> </ax-icon>\n </ax-button>\n </ax-suffix>\n</ax-toolbar>\n", styles: ["ax-image-editor-header{width:100%}ax-image-editor-header ax-toolbar{justify-content:space-between}ax-image-editor-header .ax-start-toolbar-divider{display:none}\n"] }]
103
+ }] });
104
+
105
+ /**
106
+ * paint mode.
107
+ * @category Components
108
+ */
109
+ class AXImageEditorHighlightComponent {
43
110
  constructor() {
44
- super(...arguments);
45
- /** @ignore */
46
111
  this.service = inject(AXImageEditorService);
47
- this.imageEditorContainer = viewChild('f');
48
112
  /** @ignore */
49
- this.dialogService = inject(AXDialogService);
113
+ this.selectedColor = signal(this.service.highlightColor());
50
114
  /** @ignore */
51
- this.options = signal({
52
- color: 'primary',
53
- title: 'Attention',
54
- vertical: false,
55
- content: 'Do you want to save changes?',
56
- orientation: 'vertical',
57
- draggable: true,
58
- });
115
+ this.value = this.service.highlightWidth();
59
116
  }
60
- save() {
61
- if (this.service.initialImage() !== this.service.newImage()) {
62
- this.dialogService
63
- .confirm(this.options().title, this.options().content, this.options().color, this.options().orientation, this.options().draggable)
64
- .then((data) => {
65
- if (data.result) {
66
- this.service.initialImage.set(this.service.newImage());
67
- this.commitValue(this.service.imageBlob(), true);
68
- }
69
- })
70
- .catch(() => this.commitValue(null));
71
- }
72
- else {
73
- this.commitValue(null);
74
- }
117
+ changeColorHandler(e) {
118
+ this.service.highlightColor.set(e);
119
+ this.selectedColor.set(e);
75
120
  }
76
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorContainerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
77
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.1.7", type: AXImageEditorContainerComponent, isStandalone: true, selector: "ax-image-editor-container", inputs: { look: "look" }, outputs: { onValueChanged: "onValueChanged" }, providers: [
78
- AXImageEditorService,
79
- { provide: AXComponent, useExisting: AXImageEditorContainerComponent },
80
- { provide: AXFocusableComponent, useExisting: AXImageEditorContainerComponent },
81
- { provide: AXClearableComponent, useExisting: AXImageEditorContainerComponent },
82
- { provide: AXValuableComponent, useExisting: AXImageEditorContainerComponent },
83
- {
84
- provide: NG_VALUE_ACCESSOR,
85
- useExisting: forwardRef(() => AXImageEditorContainerComponent),
86
- multi: true,
87
- },
88
- ], viewQueries: [{ propertyName: "imageEditorContainer", first: true, predicate: ["f"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "@if (service.isImageLoad()) {\n <div #f class=\"ax-editor-container ax-{{ look }}\">\n <ng-content> </ng-content>\n <ng-content select=\"ax-validation-rule\"> </ng-content>\n </div>\n <div class=\"ax-error-container\"></div>\n} @else {\n <div class=\"ax-loading-spinner-container\">\n <ax-loading-spinner [size]=\"16\" color=\"primary\" text=\"Loading Image ...\"></ax-loading-spinner>\n </div>\n}\n", styles: ["ax-image-editor-container{width:fit-content;display:block}ax-image-editor-container>.ax-editor-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:auto!important;--ax-comp-editor-space-start-size: 0;--ax-comp-editor-space-end-size: 0}ax-image-editor-container .ax-loading-spinner-container{display:flex;justify-content:center;align-items:center}\n"], dependencies: [{ kind: "component", type: AXLoadingSpinnerComponent, selector: "ax-loading-spinner", inputs: ["text", "color", "size", "stroke"] }], encapsulation: i0.ViewEncapsulation.None }); }
121
+ /** @ignore */
122
+ valueHandler(e) {
123
+ this.service.highlightWidth.set(e);
124
+ }
125
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorHighlightComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
126
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.1.8", type: AXImageEditorHighlightComponent, isStandalone: true, selector: "ax-image-editor-highlight", ngImport: i0, template: "<ax-color-box\n [showValue]=\"false\"\n [showIcon]=\"false\"\n axTooltip=\"Highlight Color Picker\"\n axTooltipPlacement=\"top\"\n look=\"none\"\n [ngModel]=\"selectedColor()\"\n (ngModelChange)=\"changeColorHandler($event)\"\n>\n</ax-color-box>\n\n<ax-range-slider [min]=\"2\" [max]=\"20\" [(ngModel)]=\"value\" (ngModelChange)=\"valueHandler($event)\"></ax-range-slider>\n", styles: ["ax-image-editor-highlight{display:flex}ax-image-editor-highlight ax-range-slider{padding:.5rem .75rem;width:10rem}ax-image-editor-highlight ax-range-slider .ax-range-slider .ax-range-slider-handler{width:1rem!important;height:1rem!important}\n"], dependencies: [{ kind: "component", type: AXColorBoxComponent, selector: "ax-color-box", inputs: ["disabled", "readonly", "tabIndex", "placeholder", "minValue", "maxValue", "value", "state", "name", "id", "type", "look", "showBadge", "showValue", "showClearButton", "showIcon"], outputs: ["valueChange", "stateChange", "onValueChanged", "onBlur", "onFocus", "readonlyChange", "disabledChange"] }, { kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: AXRangeSliderComponent, selector: "ax-range-slider", inputs: ["disabled", "readonly", "orientation", "color", "values", "mode", "min", "max", "step", "snap", "tooltipMode", "snapMode", "hasStep", "hasSnap", "hasLable", "hasTooltip"], outputs: ["valuesChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
89
127
  }
90
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorContainerComponent, decorators: [{
128
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorHighlightComponent, decorators: [{
91
129
  type: Component,
92
- args: [{ selector: 'ax-image-editor-container', encapsulation: ViewEncapsulation.None, outputs: ['onValueChanged'], inputs: ['look'], providers: [
93
- AXImageEditorService,
94
- { provide: AXComponent, useExisting: AXImageEditorContainerComponent },
95
- { provide: AXFocusableComponent, useExisting: AXImageEditorContainerComponent },
96
- { provide: AXClearableComponent, useExisting: AXImageEditorContainerComponent },
97
- { provide: AXValuableComponent, useExisting: AXImageEditorContainerComponent },
98
- {
99
- provide: NG_VALUE_ACCESSOR,
100
- useExisting: forwardRef(() => AXImageEditorContainerComponent),
101
- multi: true,
102
- },
103
- ], imports: [AXLoadingSpinnerComponent], template: "@if (service.isImageLoad()) {\n <div #f class=\"ax-editor-container ax-{{ look }}\">\n <ng-content> </ng-content>\n <ng-content select=\"ax-validation-rule\"> </ng-content>\n </div>\n <div class=\"ax-error-container\"></div>\n} @else {\n <div class=\"ax-loading-spinner-container\">\n <ax-loading-spinner [size]=\"16\" color=\"primary\" text=\"Loading Image ...\"></ax-loading-spinner>\n </div>\n}\n", styles: ["ax-image-editor-container{width:fit-content;display:block}ax-image-editor-container>.ax-editor-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:auto!important;--ax-comp-editor-space-start-size: 0;--ax-comp-editor-space-end-size: 0}ax-image-editor-container .ax-loading-spinner-container{display:flex;justify-content:center;align-items:center}\n"] }]
130
+ args: [{ selector: 'ax-image-editor-highlight', encapsulation: ViewEncapsulation.None, imports: [AXColorBoxComponent, CommonModule, FormsModule, AXRangeSliderComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ax-color-box\n [showValue]=\"false\"\n [showIcon]=\"false\"\n axTooltip=\"Highlight Color Picker\"\n axTooltipPlacement=\"top\"\n look=\"none\"\n [ngModel]=\"selectedColor()\"\n (ngModelChange)=\"changeColorHandler($event)\"\n>\n</ax-color-box>\n\n<ax-range-slider [min]=\"2\" [max]=\"20\" [(ngModel)]=\"value\" (ngModelChange)=\"valueHandler($event)\"></ax-range-slider>\n", styles: ["ax-image-editor-highlight{display:flex}ax-image-editor-highlight ax-range-slider{padding:.5rem .75rem;width:10rem}ax-image-editor-highlight ax-range-slider .ax-range-slider .ax-range-slider-handler{width:1rem!important;height:1rem!important}\n"] }]
104
131
  }] });
105
132
 
106
133
  /**
107
- * paint color picker.
134
+ * paint mode.
108
135
  * @category Components
109
136
  */
110
- class AXImageEditorColorPickerComponent {
137
+ class AXImageEditorPenComponent {
111
138
  constructor() {
112
- /** @ignore */
113
139
  this.service = inject(AXImageEditorService);
114
140
  /** @ignore */
115
- this.selectedColor = signal('rgb(12, 12, 12)');
141
+ this.value = this.service.penWidth();
142
+ /** @ignore */
143
+ this.selectedColor = signal(this.service.penColor());
116
144
  }
117
- /** @ignore */
118
145
  changeColorHandler(e) {
119
146
  this.service.penColor.set(e);
120
147
  this.selectedColor.set(e);
121
148
  }
122
- get __hostClass() {
123
- return `.5rem`;
149
+ /** @ignore */
150
+ valueHandler(e) {
151
+ this.service.penWidth.set(e);
124
152
  }
125
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorColorPickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
126
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.1.7", type: AXImageEditorColorPickerComponent, isStandalone: true, selector: "ax-image-editor-color-picker", host: { properties: { "style.marginInline": "this.__hostClass" } }, ngImport: i0, template: "<ax-color-box axTooltip=\"Color Picker\" axTooltipPlacement=\"top\" look=\"none\" [ngModel]=\"selectedColor()\" (ngModelChange)=\"changeColorHandler($event)\">\n</ax-color-box>\n", styles: ["ax-image-editor-color-picker{margin-inline:0!important}ax-image-editor-color-picker .ax-submit-color{border:1px solid rgba(var(--ax-sys-body-text-color));width:.6rem;height:.6rem;border-radius:1000vmax}ax-image-editor-color-picker .ax-color-flex-container{display:flex;align-items:center;cursor:pointer}\n"], dependencies: [{ kind: "component", type: AXColorBoxComponent, selector: "ax-color-box", inputs: ["disabled", "readonly", "tabIndex", "placeholder", "minValue", "maxValue", "value", "state", "name", "id", "type", "look", "showBadge", "showValue", "showClearButton", "showIcon"], outputs: ["valueChange", "stateChange", "onValueChanged", "onBlur", "onFocus", "readonlyChange", "disabledChange"] }, { kind: "directive", type: AXTooltipDirective, selector: "[axTooltip]", inputs: ["axTooltip", "axTooltipPlacement", "axTooltipOpenAfter", "axTooltipCloseAfter"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], encapsulation: i0.ViewEncapsulation.None }); }
153
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorPenComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
154
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.1.8", type: AXImageEditorPenComponent, isStandalone: true, selector: "ax-image-editor-pen", ngImport: i0, template: "<ax-color-box\n [showValue]=\"false\"\n [showIcon]=\"false\"\n axTooltip=\"Pen Color Picker\"\n axTooltipPlacement=\"top\"\n look=\"none\"\n [ngModel]=\"selectedColor()\"\n (ngModelChange)=\"changeColorHandler($event)\"\n>\n</ax-color-box>\n\n<ax-range-slider [min]=\"2\" [max]=\"20\" [(ngModel)]=\"value\" (ngModelChange)=\"valueHandler($event)\"></ax-range-slider>\n", styles: ["ax-image-editor-pen{display:flex}ax-image-editor-pen ax-range-slider{padding:.5rem .75rem;width:10rem}ax-image-editor-pen ax-range-slider .ax-range-slider .ax-range-slider-handler{width:1rem!important;height:1rem!important}\n"], dependencies: [{ kind: "component", type: AXColorBoxComponent, selector: "ax-color-box", inputs: ["disabled", "readonly", "tabIndex", "placeholder", "minValue", "maxValue", "value", "state", "name", "id", "type", "look", "showBadge", "showValue", "showClearButton", "showIcon"], outputs: ["valueChange", "stateChange", "onValueChanged", "onBlur", "onFocus", "readonlyChange", "disabledChange"] }, { kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: AXRangeSliderComponent, selector: "ax-range-slider", inputs: ["disabled", "readonly", "orientation", "color", "values", "mode", "min", "max", "step", "snap", "tooltipMode", "snapMode", "hasStep", "hasSnap", "hasLable", "hasTooltip"], outputs: ["valuesChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
127
155
  }
128
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorColorPickerComponent, decorators: [{
156
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorPenComponent, decorators: [{
129
157
  type: Component,
130
- args: [{ selector: 'ax-image-editor-color-picker', encapsulation: ViewEncapsulation.None, imports: [AXColorBoxComponent, AXTooltipDirective, FormsModule], template: "<ax-color-box axTooltip=\"Color Picker\" axTooltipPlacement=\"top\" look=\"none\" [ngModel]=\"selectedColor()\" (ngModelChange)=\"changeColorHandler($event)\">\n</ax-color-box>\n", styles: ["ax-image-editor-color-picker{margin-inline:0!important}ax-image-editor-color-picker .ax-submit-color{border:1px solid rgba(var(--ax-sys-body-text-color));width:.6rem;height:.6rem;border-radius:1000vmax}ax-image-editor-color-picker .ax-color-flex-container{display:flex;align-items:center;cursor:pointer}\n"] }]
131
- }], propDecorators: { __hostClass: [{
132
- type: HostBinding,
133
- args: ['style.marginInline']
134
- }] } });
158
+ args: [{ selector: 'ax-image-editor-pen', encapsulation: ViewEncapsulation.None, imports: [AXColorBoxComponent, CommonModule, FormsModule, AXRangeSliderComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ax-color-box\n [showValue]=\"false\"\n [showIcon]=\"false\"\n axTooltip=\"Pen Color Picker\"\n axTooltipPlacement=\"top\"\n look=\"none\"\n [ngModel]=\"selectedColor()\"\n (ngModelChange)=\"changeColorHandler($event)\"\n>\n</ax-color-box>\n\n<ax-range-slider [min]=\"2\" [max]=\"20\" [(ngModel)]=\"value\" (ngModelChange)=\"valueHandler($event)\"></ax-range-slider>\n", styles: ["ax-image-editor-pen{display:flex}ax-image-editor-pen ax-range-slider{padding:.5rem .75rem;width:10rem}ax-image-editor-pen ax-range-slider .ax-range-slider .ax-range-slider-handler{width:1rem!important;height:1rem!important}\n"] }]
159
+ }] });
135
160
 
136
161
  /**
137
162
  * paint mode.
138
163
  * @category Components
139
164
  */
140
- class AXImageEditorCropComponent {
165
+ class AXImageEditorRotateComponent {
141
166
  constructor() {
142
167
  /** @ignore */
143
168
  this.service = inject(AXImageEditorService);
@@ -150,67 +175,39 @@ class AXImageEditorCropComponent {
150
175
  rotateLeftHandler() {
151
176
  this.service.rotate.set({ state: -90, userInteract: true });
152
177
  }
153
- /** @ignore */
154
- crop() {
155
- this.service.cropState.update((prev) => {
156
- return { userInteract: true, state: !prev.state };
157
- });
158
- }
159
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorCropComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
160
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.1.7", type: AXImageEditorCropComponent, isStandalone: true, selector: "ax-image-editor-crop", ngImport: i0, template: "<ax-button\n axTooltip=\"Crop Image\"\n axTooltipPlacement=\"top\"\n [selected]=\"service.cropState().state && true\"\n (click)=\"crop()\"\n look=\"blank\"\n>\n <ax-icon class=\"ax-icon ax-icon-crop\"></ax-icon>\n</ax-button>\n\n<ax-button axTooltip=\"Rotate Left\" axTooltipPlacement=\"top\" (click)=\"rotateLeftHandler()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-undo\"></ax-icon>\n</ax-button>\n\n<ax-button axTooltip=\"Rotate Right\" axTooltipPlacement=\"top\" (click)=\"rotateRightHandler()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-redo\"></ax-icon>\n</ax-button>\n", dependencies: [{ kind: "component", type: AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "loadingTextChange"] }, { kind: "directive", type: AXTooltipDirective, selector: "[axTooltip]", inputs: ["axTooltip", "axTooltipPlacement", "axTooltipOpenAfter", "axTooltipCloseAfter"] }, { kind: "component", type: AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }], encapsulation: i0.ViewEncapsulation.None }); }
178
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorRotateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
179
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.1.8", type: AXImageEditorRotateComponent, isStandalone: true, selector: "ax-image-editor-rotate", ngImport: i0, template: "<ax-button axTooltip=\"Rotate Left\" axTooltipPlacement=\"top\" (click)=\"rotateLeftHandler()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-arrow-turn-left\"></ax-icon>\n</ax-button>\n\n<ax-button axTooltip=\"Rotate Right\" axTooltipPlacement=\"top\" (click)=\"rotateRightHandler()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-arrow-turn-right\"></ax-icon>\n</ax-button>\n", dependencies: [{ kind: "component", type: AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "loadingTextChange"] }, { kind: "directive", type: AXTooltipDirective, selector: "[axTooltip]", inputs: ["axTooltip", "axTooltipPlacement", "axTooltipOpenAfter", "axTooltipCloseAfter"] }, { kind: "component", type: AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
161
180
  }
162
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorCropComponent, decorators: [{
181
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorRotateComponent, decorators: [{
163
182
  type: Component,
164
- args: [{ selector: 'ax-image-editor-crop', encapsulation: ViewEncapsulation.None, imports: [AXButtonComponent, AXTooltipDirective, AXDecoratorIconComponent], template: "<ax-button\n axTooltip=\"Crop Image\"\n axTooltipPlacement=\"top\"\n [selected]=\"service.cropState().state && true\"\n (click)=\"crop()\"\n look=\"blank\"\n>\n <ax-icon class=\"ax-icon ax-icon-crop\"></ax-icon>\n</ax-button>\n\n<ax-button axTooltip=\"Rotate Left\" axTooltipPlacement=\"top\" (click)=\"rotateLeftHandler()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-undo\"></ax-icon>\n</ax-button>\n\n<ax-button axTooltip=\"Rotate Right\" axTooltipPlacement=\"top\" (click)=\"rotateRightHandler()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-redo\"></ax-icon>\n</ax-button>\n" }]
183
+ args: [{ selector: 'ax-image-editor-rotate', encapsulation: ViewEncapsulation.None, imports: [AXButtonComponent, AXTooltipDirective, AXDecoratorIconComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ax-button axTooltip=\"Rotate Left\" axTooltipPlacement=\"top\" (click)=\"rotateLeftHandler()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-arrow-turn-left\"></ax-icon>\n</ax-button>\n\n<ax-button axTooltip=\"Rotate Right\" axTooltipPlacement=\"top\" (click)=\"rotateRightHandler()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-arrow-turn-right\"></ax-icon>\n</ax-button>\n" }]
165
184
  }] });
166
185
 
167
186
  /**
168
187
  * paint mode.
169
188
  * @category Components
170
189
  */
171
- class AXImageEditorPenModeChangerComponent {
190
+ class AXImageEditorToolSelectorComponent {
172
191
  constructor() {
173
- /** @ignore */
174
192
  this.service = inject(AXImageEditorService);
175
- /** @ignore */
176
- this.value = 10;
177
- /** @ignore */
178
- this.popoverOption = {
179
- openOn: 'click',
180
- closeOn: 'clickOut',
181
- placement: 'top',
182
- offsetX: 0,
183
- offsetY: 0,
184
- };
185
- /** @ignore */
186
- this.selectedPenType = signal('pen');
187
- }
188
- /** @ignore */
189
- penTypeHandler(e) {
190
- this.service.penType.set(e);
191
- }
192
- /** @ignore */
193
- clear() {
194
- this.service.toggleClear.set({ userInteract: true, state: true });
195
- }
196
- /** @ignore */
197
- get __hostClass() {
198
- return `.5rem`;
199
193
  }
200
- /** @ignore */
201
- valueHandler(e) {
202
- this.service.lineWidth.set(e);
194
+ changeToolHandler(tool) {
195
+ if (this.service.activeToolState() === tool) {
196
+ this.service.activeToolState.set(null);
197
+ return;
198
+ }
199
+ this.service.activeToolState.set(tool);
200
+ if (tool === 'pen' || tool === 'highlight') {
201
+ this.service.penType.set(tool);
202
+ }
203
203
  }
204
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorPenModeChangerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
205
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.1.7", type: AXImageEditorPenModeChangerComponent, isStandalone: true, selector: "ax-image-editor-pen-mode-changer", host: { properties: { "style.marginInline": "this.__hostClass" } }, ngImport: i0, template: "<ax-button axTooltip=\"Draw Utilities\" axTooltipPlacement=\"top\" look=\"blank\" #alignPop>\n @switch (service.penType()) {\n @case ('pen') {\n <ax-icon class=\"ax-icon ax-icon-pen\"></ax-icon>\n }\n @case ('highlight') {\n <ax-icon class=\"ax-icon ax-icon-highlight\"></ax-icon>\n }\n }\n</ax-button>\n\n<ax-button axTooltip=\"Reset Changes\" axTooltipPlacement=\"top\" (click)=\"clear()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-refresh\"></ax-icon>\n</ax-button>\n\n<ax-popover\n [openOn]=\"popoverOption.openOn\"\n [closeOn]=\"popoverOption.closeOn\"\n [target]=\"alignPop\"\n [placement]=\"popoverOption.placement\"\n>\n <div class=\"ax-overlay-pane\">\n <ax-button\n (click)=\"penTypeHandler('pen')\"\n look=\"blank\"\n [selected]=\"this.service.penType() === 'pen' ? true : false\"\n >\n <ax-icon class=\"ax-icon ax-icon-pen\"></ax-icon>\n </ax-button>\n\n <ax-button\n (click)=\"penTypeHandler('highlight')\"\n look=\"blank\"\n [selected]=\"this.service.penType() === 'highlight' ? true : false\"\n >\n <ax-icon class=\"ax-icon ax-icon-highlight\"></ax-icon>\n </ax-button>\n\n <div class=\"ax-paint-width-slider\">\n <ax-range-slider\n [min]=\"2\"\n [max]=\"20\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"valueHandler($event)\"\n ></ax-range-slider>\n </div>\n </div>\n</ax-popover>\n", styles: ["ax-image-editor-pen-mode-changer{margin-inline:0!important}ax-image-editor-pen-mode-changer ax-range-slider{padding:.5rem .75rem}ax-image-editor-pen-mode-changer ax-range-slider .ax-range-slider .ax-range-slider-handler{width:1rem!important;height:1rem!important}ax-image-editor-pen-mode-changer .ax-paint-pen-mode-changer-container{display:flex;align-items:center}ax-image-editor-pen-mode-changer .ax-paint-pen-mode-changer-container .ax-pen-type-container{margin-inline-end:.5rem}ax-image-editor-pen-mode-changer .ax-overlay-pane{padding:.5rem!important}\n"], dependencies: [{ kind: "component", type: AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "loadingTextChange"] }, { kind: "directive", type: AXTooltipDirective, selector: "[axTooltip]", inputs: ["axTooltip", "axTooltipPlacement", "axTooltipOpenAfter", "axTooltipCloseAfter"] }, { kind: "component", type: AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: AXPopoverComponent, selector: "ax-popover", inputs: ["offsetX", "offsetY", "target", "placement", "content", "openOn", "closeOn", "hasBackdrop", "openAfter", "closeAfter", "backdropClass", "panelClass", "adaptivityEnabled"], outputs: ["onOpened", "onClosed"] }, { kind: "component", type: AXRangeSliderComponent, selector: "ax-range-slider", inputs: ["disabled", "readonly", "orientation", "color", "values", "mode", "min", "max", "step", "snap", "tooltipMode", "snapMode", "hasStep", "hasSnap", "hasLable", "hasTooltip"], outputs: ["valuesChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], encapsulation: i0.ViewEncapsulation.None }); }
204
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorToolSelectorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
205
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.1.8", type: AXImageEditorToolSelectorComponent, isStandalone: true, selector: "ax-image-editor-tool-selector", ngImport: i0, template: "<ax-button\n axTooltip=\"pen\"\n axTooltipPlacement=\"top\"\n (onClick)=\"changeToolHandler('pen')\"\n look=\"blank\"\n [selected]=\"this.service.activeToolState() === 'pen' ? true : false\"\n [color]=\"this.service.activeToolState() === 'pen' ? 'primary' : 'default'\"\n>\n <ax-icon class=\"ax-icon ax-icon-pen\"></ax-icon>\n</ax-button>\n\n<ax-button\n axTooltip=\"highlight\"\n axTooltipPlacement=\"top\"\n (onClick)=\"changeToolHandler('highlight')\"\n look=\"blank\"\n [selected]=\"this.service.activeToolState() === 'highlight' ? true : false\"\n [color]=\"this.service.activeToolState() === 'highlight' ? 'primary' : 'default'\"\n>\n <ax-icon class=\"ax-icon ax-icon-highlight\"></ax-icon>\n</ax-button>\n\n<ax-button\n axTooltip=\"crop\"\n axTooltipPlacement=\"top\"\n (onClick)=\"changeToolHandler('crop')\"\n look=\"blank\"\n [selected]=\"this.service.activeToolState() === 'crop' ? true : false\"\n [color]=\"this.service.activeToolState() === 'crop' ? 'primary' : 'default'\"\n>\n <ax-icon class=\"ax-icon ax-icon-crop\"></ax-icon>\n</ax-button>\n\n<ax-button\n axTooltip=\"rotate\"\n axTooltipPlacement=\"top\"\n (onClick)=\"changeToolHandler('rotate')\"\n look=\"blank\"\n [selected]=\"this.service.activeToolState() === 'rotate' ? true : false\"\n [color]=\"this.service.activeToolState() === 'rotate' ? 'primary' : 'default'\"\n>\n <i class=\"fa-solid fa-rotate\"></i>\n</ax-button>\n", dependencies: [{ kind: "component", type: AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "loadingTextChange"] }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type: i1.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "directive", type: AXTooltipDirective, selector: "[axTooltip]", inputs: ["axTooltip", "axTooltipPlacement", "axTooltipOpenAfter", "axTooltipCloseAfter"] }], encapsulation: i0.ViewEncapsulation.None }); }
206
206
  }
207
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorPenModeChangerComponent, decorators: [{
207
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorToolSelectorComponent, decorators: [{
208
208
  type: Component,
209
- args: [{ selector: 'ax-image-editor-pen-mode-changer', encapsulation: ViewEncapsulation.None, imports: [AXButtonComponent, AXTooltipDirective, AXDecoratorIconComponent, AXPopoverComponent, AXRangeSliderComponent, FormsModule], template: "<ax-button axTooltip=\"Draw Utilities\" axTooltipPlacement=\"top\" look=\"blank\" #alignPop>\n @switch (service.penType()) {\n @case ('pen') {\n <ax-icon class=\"ax-icon ax-icon-pen\"></ax-icon>\n }\n @case ('highlight') {\n <ax-icon class=\"ax-icon ax-icon-highlight\"></ax-icon>\n }\n }\n</ax-button>\n\n<ax-button axTooltip=\"Reset Changes\" axTooltipPlacement=\"top\" (click)=\"clear()\" look=\"blank\">\n <ax-icon class=\"ax-icon ax-icon-refresh\"></ax-icon>\n</ax-button>\n\n<ax-popover\n [openOn]=\"popoverOption.openOn\"\n [closeOn]=\"popoverOption.closeOn\"\n [target]=\"alignPop\"\n [placement]=\"popoverOption.placement\"\n>\n <div class=\"ax-overlay-pane\">\n <ax-button\n (click)=\"penTypeHandler('pen')\"\n look=\"blank\"\n [selected]=\"this.service.penType() === 'pen' ? true : false\"\n >\n <ax-icon class=\"ax-icon ax-icon-pen\"></ax-icon>\n </ax-button>\n\n <ax-button\n (click)=\"penTypeHandler('highlight')\"\n look=\"blank\"\n [selected]=\"this.service.penType() === 'highlight' ? true : false\"\n >\n <ax-icon class=\"ax-icon ax-icon-highlight\"></ax-icon>\n </ax-button>\n\n <div class=\"ax-paint-width-slider\">\n <ax-range-slider\n [min]=\"2\"\n [max]=\"20\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"valueHandler($event)\"\n ></ax-range-slider>\n </div>\n </div>\n</ax-popover>\n", styles: ["ax-image-editor-pen-mode-changer{margin-inline:0!important}ax-image-editor-pen-mode-changer ax-range-slider{padding:.5rem .75rem}ax-image-editor-pen-mode-changer ax-range-slider .ax-range-slider .ax-range-slider-handler{width:1rem!important;height:1rem!important}ax-image-editor-pen-mode-changer .ax-paint-pen-mode-changer-container{display:flex;align-items:center}ax-image-editor-pen-mode-changer .ax-paint-pen-mode-changer-container .ax-pen-type-container{margin-inline-end:.5rem}ax-image-editor-pen-mode-changer .ax-overlay-pane{padding:.5rem!important}\n"] }]
210
- }], propDecorators: { __hostClass: [{
211
- type: HostBinding,
212
- args: ['style.marginInline']
213
- }] } });
209
+ args: [{ selector: 'ax-image-editor-tool-selector', encapsulation: ViewEncapsulation.None, imports: [AXButtonComponent, AXDecoratorModule, AXTooltipDirective], template: "<ax-button\n axTooltip=\"pen\"\n axTooltipPlacement=\"top\"\n (onClick)=\"changeToolHandler('pen')\"\n look=\"blank\"\n [selected]=\"this.service.activeToolState() === 'pen' ? true : false\"\n [color]=\"this.service.activeToolState() === 'pen' ? 'primary' : 'default'\"\n>\n <ax-icon class=\"ax-icon ax-icon-pen\"></ax-icon>\n</ax-button>\n\n<ax-button\n axTooltip=\"highlight\"\n axTooltipPlacement=\"top\"\n (onClick)=\"changeToolHandler('highlight')\"\n look=\"blank\"\n [selected]=\"this.service.activeToolState() === 'highlight' ? true : false\"\n [color]=\"this.service.activeToolState() === 'highlight' ? 'primary' : 'default'\"\n>\n <ax-icon class=\"ax-icon ax-icon-highlight\"></ax-icon>\n</ax-button>\n\n<ax-button\n axTooltip=\"crop\"\n axTooltipPlacement=\"top\"\n (onClick)=\"changeToolHandler('crop')\"\n look=\"blank\"\n [selected]=\"this.service.activeToolState() === 'crop' ? true : false\"\n [color]=\"this.service.activeToolState() === 'crop' ? 'primary' : 'default'\"\n>\n <ax-icon class=\"ax-icon ax-icon-crop\"></ax-icon>\n</ax-button>\n\n<ax-button\n axTooltip=\"rotate\"\n axTooltipPlacement=\"top\"\n (onClick)=\"changeToolHandler('rotate')\"\n look=\"blank\"\n [selected]=\"this.service.activeToolState() === 'rotate' ? true : false\"\n [color]=\"this.service.activeToolState() === 'rotate' ? 'primary' : 'default'\"\n>\n <i class=\"fa-solid fa-rotate\"></i>\n</ax-button>\n" }]
210
+ }] });
214
211
 
215
212
  class AXImageEditorViewComponent extends MXBaseComponent {
216
213
  /** @ignore */
@@ -264,12 +261,16 @@ class AXImageEditorViewComponent extends MXBaseComponent {
264
261
  /** @ignore */
265
262
  this.cropEndY = signal(0);
266
263
  /** @ignore */
264
+ this.isDrawRectangleCreated = signal(false);
265
+ /** @ignore */
267
266
  this.parent = inject(AXImageEditorContainerComponent);
268
267
  this.renderer = inject(Renderer2);
269
268
  /** @ignore */
270
269
  this.imageAspect = computed(() => {
271
270
  return this.service.initialImage().width / this.service.initialImage().height;
272
271
  });
272
+ this.imageEditorHistory = signal([]);
273
+ this.imageEditorHistoryPointer = linkedSignal(() => this.imageEditorHistory().length - 1);
273
274
  this.ngZone = inject(NgZone);
274
275
  afterNextRender(() => {
275
276
  this.resizeEventListener = this.renderer.listen(window, 'resize', this.resizeWindow.bind(this));
@@ -281,11 +282,7 @@ class AXImageEditorViewComponent extends MXBaseComponent {
281
282
  //set canvas options
282
283
  this.ctx.set(this.canvasElem().nativeElement.getContext('2d', { willReadFrequently: true }));
283
284
  this.ctx().lineJoin = 'round';
284
- this.ctx().lineCap = this.service.lineCap();
285
- this.ctx().strokeStyle = this.service.penColor();
286
- this.ctx().lineWidth = this.service.lineWidth();
287
- this.ctx().globalCompositeOperation = 'source-over';
288
- this.ctx().globalAlpha = 1;
285
+ this.ctx().lineCap = 'round';
289
286
  });
290
287
  effect(() => {
291
288
  if (this.parent.imageEditorContainer() && this.service.isImageLoad()) {
@@ -293,21 +290,27 @@ class AXImageEditorViewComponent extends MXBaseComponent {
293
290
  }
294
291
  });
295
292
  effect(() => {
296
- if (!this.service.toggleClear().userInteract)
297
- return;
298
- if (this.service.toggleClear().state) {
299
- this.imageLoaded();
293
+ if (!this.service.undoPressed()) {
294
+ this.imageChanged();
295
+ }
296
+ });
297
+ effect(() => {
298
+ if (!this.service.redoPressed()) {
299
+ this.imageChanged();
300
300
  }
301
301
  });
302
302
  effect(() => {
303
- if (!this.service.cropState().userInteract || !this.ctx())
303
+ if (!this.ctx())
304
304
  return;
305
- if (this.service.cropState().state) {
305
+ this.ctx().globalAlpha = 1;
306
+ if (this.service.activeToolState() === 'crop') {
306
307
  this.ctx().filter = 'brightness(40%)';
307
308
  }
308
309
  else {
309
310
  this.ctx().filter = 'brightness(100%)';
310
311
  }
312
+ if (!this.service.newImage())
313
+ return;
311
314
  this.ctx().drawImage(this.service.newImage(), 0, 0, this.service.newImage().width, this.service.newImage().height);
312
315
  });
313
316
  effect(() => {
@@ -327,19 +330,37 @@ class AXImageEditorViewComponent extends MXBaseComponent {
327
330
  }
328
331
  /** @ignore */
329
332
  imageLoaded() {
333
+ this.imageEditorHistory.set([this.service.initialImage()]);
330
334
  this.service.newImage.set(this.service.initialImage());
331
- this.service.toggleClear.set({ userInteract: false, state: false });
332
335
  this.service.isImageLoad.set(true);
333
- this.canvasResponsive(this.service.initialImage());
336
+ }
337
+ /** @ignore */
338
+ imageChanged() {
339
+ if (this.service.undoPressed() && this.imageEditorHistoryPointer() >= 1) {
340
+ this.imageEditorHistoryPointer.update((prev) => prev - 1);
341
+ this.service.newImage.set(this.imageEditorHistory()[this.imageEditorHistoryPointer()]);
342
+ this.canvasResponsive(this.imageEditorHistory()[this.imageEditorHistoryPointer()]);
343
+ }
344
+ if (this.service.redoPressed() && this.imageEditorHistoryPointer() < this.imageEditorHistory().length - 1) {
345
+ this.imageEditorHistoryPointer.update((prev) => prev + 1);
346
+ this.service.newImage.set(this.imageEditorHistory()[this.imageEditorHistoryPointer()]);
347
+ this.canvasResponsive(this.imageEditorHistory()[this.imageEditorHistoryPointer()]);
348
+ }
349
+ this.service.undoPressed.set(false);
350
+ this.service.redoPressed.set(false);
334
351
  }
335
352
  /** @ignore */
336
353
  penConfigHandler(penType) {
337
354
  switch (penType) {
338
355
  case 'pen':
339
356
  this.ctx().globalAlpha = 1;
357
+ this.ctx().strokeStyle = this.service.penColor();
358
+ this.ctx().lineWidth = this.service.penWidth();
340
359
  break;
341
360
  case 'highlight':
342
361
  this.ctx().globalAlpha = 0.008;
362
+ this.ctx().strokeStyle = this.service.highlightColor();
363
+ this.ctx().lineWidth = this.service.highlightWidth();
343
364
  break;
344
365
  }
345
366
  }
@@ -350,16 +371,15 @@ class AXImageEditorViewComponent extends MXBaseComponent {
350
371
  /** @ignore */
351
372
  mouseDownHandler(e) {
352
373
  this.isMouseDown.set(true);
353
- if (this.service.cropState().state) {
374
+ if (this.service.activeToolState() === 'crop') {
354
375
  this.cropStartX.set(e.offsetX);
355
376
  this.cropStartY.set(e.offsetY);
356
377
  this.cropEndX.set(0);
357
378
  }
358
379
  else {
380
+ if (!this.service.penType())
381
+ return;
359
382
  this.penConfigHandler(this.service.penType());
360
- this.ctx().strokeStyle = this.service.penColor();
361
- this.ctx().lineCap = this.service.lineCap();
362
- this.ctx().lineWidth = this.service.lineWidth();
363
383
  this.ctx().beginPath();
364
384
  this.ctx().moveTo(e.offsetX, e.offsetY);
365
385
  this.ctx().lineTo(e.offsetX, e.offsetY);
@@ -370,13 +390,15 @@ class AXImageEditorViewComponent extends MXBaseComponent {
370
390
  mouseMoveHandler(e) {
371
391
  if (!this.isMouseDown())
372
392
  return;
373
- if (this.service.cropState().state) {
393
+ if (this.service.activeToolState() === 'crop') {
374
394
  this.ctx().globalCompositeOperation = 'screen';
375
395
  this.cropEndX.set(e.offsetX);
376
396
  this.cropEndY.set(e.offsetY);
377
397
  this.drawSelection();
378
398
  }
379
399
  else {
400
+ if (!this.service.penType())
401
+ return;
380
402
  this.ctx().lineTo(e.offsetX, e.offsetY);
381
403
  this.ctx().stroke();
382
404
  }
@@ -384,7 +406,7 @@ class AXImageEditorViewComponent extends MXBaseComponent {
384
406
  /** @ignore */
385
407
  mouseUpHandler() {
386
408
  this.isMouseDown.set(false);
387
- if (this.service.cropState().state && this.cropEndX()) {
409
+ if (this.service.activeToolState() === 'crop' && this.cropEndX()) {
388
410
  this.ctx().globalCompositeOperation = 'source-over';
389
411
  this.cropImageFunction();
390
412
  }
@@ -395,19 +417,18 @@ class AXImageEditorViewComponent extends MXBaseComponent {
395
417
  }
396
418
  /** @ignore */
397
419
  touchStartHandler(e) {
420
+ this.isMouseDown.set(true);
398
421
  const offsetX = e.touches[0].clientX - this.getBoundingCanvasHandler().left;
399
422
  const offsetY = e.touches[0].clientY - this.getBoundingCanvasHandler().top;
400
- this.isMouseDown.set(true);
401
- if (this.service.cropState().state) {
423
+ if (this.service.activeToolState() === 'crop') {
402
424
  this.cropStartX.set(offsetX);
403
425
  this.cropStartY.set(offsetY);
404
426
  this.cropEndX.set(0);
405
427
  }
406
428
  else {
429
+ if (!this.service.penType())
430
+ return;
407
431
  this.penConfigHandler(this.service.penType());
408
- this.ctx().strokeStyle = this.service.penColor();
409
- this.ctx().lineCap = this.service.lineCap();
410
- this.ctx().lineWidth = this.service.lineWidth();
411
432
  this.ctx().beginPath();
412
433
  this.ctx().moveTo(offsetX, offsetY);
413
434
  this.ctx().lineTo(offsetX, offsetY);
@@ -421,13 +442,15 @@ class AXImageEditorViewComponent extends MXBaseComponent {
421
442
  return;
422
443
  const offsetX = e.touches[0].clientX - this.getBoundingCanvasHandler().left;
423
444
  const offsetY = e.touches[0].clientY - this.getBoundingCanvasHandler().top;
424
- if (this.service.cropState().state) {
445
+ if (this.service.activeToolState() === 'crop') {
425
446
  this.ctx().globalCompositeOperation = 'screen';
426
447
  this.cropEndX.set(offsetX);
427
448
  this.cropEndY.set(offsetY);
428
449
  this.drawSelection();
429
450
  }
430
451
  else {
452
+ if (!this.service.penType())
453
+ return;
431
454
  this.ctx().lineTo(offsetX, offsetY);
432
455
  this.ctx().stroke();
433
456
  }
@@ -435,7 +458,7 @@ class AXImageEditorViewComponent extends MXBaseComponent {
435
458
  /** @ignore */
436
459
  touchEndHandler() {
437
460
  this.isMouseDown.set(false);
438
- if (this.service.cropState().state && this.cropEndX()) {
461
+ if (this.service.activeToolState() === 'crop' && this.cropEndX()) {
439
462
  this.ctx().globalCompositeOperation = 'source-over';
440
463
  this.cropImageFunction();
441
464
  }
@@ -456,6 +479,7 @@ class AXImageEditorViewComponent extends MXBaseComponent {
456
479
  this.ctx().lineWidth = 2;
457
480
  this.ctx().strokeRect(this.cropStartX(), this.cropStartY(), cropWidth, cropHeight);
458
481
  });
482
+ this.isDrawRectangleCreated.set(true);
459
483
  }
460
484
  /** @ignore */
461
485
  cropImageFunction() {
@@ -497,6 +521,8 @@ class AXImageEditorViewComponent extends MXBaseComponent {
497
521
  }
498
522
  /** @ignore */
499
523
  cropButtonHandler() {
524
+ if (!this.isDrawRectangleCreated())
525
+ return;
500
526
  let cropWidth;
501
527
  let cropHeight;
502
528
  this.service.rotate.update((prev) => {
@@ -523,7 +549,8 @@ class AXImageEditorViewComponent extends MXBaseComponent {
523
549
  this.ctx().putImageData(this.cropImageData(), 0, 0);
524
550
  this.saveImageChange();
525
551
  this.cropImageData.set(null);
526
- this.service.cropState.set({ userInteract: false, state: false });
552
+ this.service.activeToolState.set(null);
553
+ this.isDrawRectangleCreated.set(false);
527
554
  }
528
555
  /** @ignore */
529
556
  rotateImage() {
@@ -544,6 +571,7 @@ class AXImageEditorViewComponent extends MXBaseComponent {
544
571
  newImage.crossOrigin = 'anonymous';
545
572
  newImage.src = this.canvasElem().nativeElement.toDataURL('image/jpeg', 1);
546
573
  this.service.newImage.set(newImage);
574
+ this.imageEditorHistory.update((prev) => [...prev, newImage]);
547
575
  const tempBlob = [];
548
576
  this.canvasElem().nativeElement.toBlob((blob) => {
549
577
  tempBlob.push(blob);
@@ -560,23 +588,111 @@ class AXImageEditorViewComponent extends MXBaseComponent {
560
588
  get __hostStyle() {
561
589
  return `width: ${this.service.initialImage()?.width}px; height: ${this.service.initialImage()?.height}px`;
562
590
  }
563
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
564
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "19.1.7", type: AXImageEditorViewComponent, isStandalone: true, selector: "ax-image-editor-view", inputs: { src: { classPropertyName: "src", publicName: "src", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "style": "this.__hostStyle" } }, viewQueries: [{ propertyName: "canvasElem", first: true, predicate: ["canvasElem"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<canvas\n tabindex=\"1\"\n (mousedown)=\"mouseDownHandler($event)\"\n (mouseup)=\"mouseUpHandler()\"\n (mousemove)=\"mouseMoveHandler($event)\"\n (touchstart)=\"touchStartHandler($event)\"\n (touchend)=\"touchEndHandler()\"\n (touchmove)=\"touchMoveHandler($event)\"\n class=\"ax-canvas-element\"\n #canvasElem\n></canvas>\n<ax-button\n (click)=\"cropButtonHandler()\"\n [style]=\"{ display: service.cropState().state ? 'block' : 'none' }\"\n class=\"ax-crop-save ax-sm\"\n text=\"Crop\"\n></ax-button>\n", styles: ["ax-image-editor-view{position:relative;display:flex;justify-content:center;align-items:center;background-color:#fff;width:100%}ax-image-editor-view .ax-canvas-element{cursor:crosshair}ax-image-editor-view .ax-crop-save{position:absolute;top:0;right:0;margin:1rem}\n"], dependencies: [{ kind: "component", type: AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "loadingTextChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
591
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorViewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
592
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "19.1.8", type: AXImageEditorViewComponent, isStandalone: true, selector: "ax-image-editor-view", inputs: { src: { classPropertyName: "src", publicName: "src", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "style": "this.__hostStyle" } }, viewQueries: [{ propertyName: "canvasElem", first: true, predicate: ["canvasElem"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<canvas\n tabindex=\"1\"\n (mousedown)=\"mouseDownHandler($event)\"\n (mouseup)=\"mouseUpHandler()\"\n (mousemove)=\"mouseMoveHandler($event)\"\n (touchstart)=\"touchStartHandler($event)\"\n (touchend)=\"touchEndHandler()\"\n (touchmove)=\"touchMoveHandler($event)\"\n class=\"ax-canvas-element\"\n #canvasElem\n></canvas>\n", styles: ["ax-image-editor-view{position:relative;display:flex;justify-content:center;align-items:center;background-color:#fff;width:100%}ax-image-editor-view .ax-canvas-element{cursor:crosshair}ax-image-editor-view .ax-crop-save{position:absolute;top:0;right:0;margin:1rem}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
565
593
  }
566
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorViewComponent, decorators: [{
594
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorViewComponent, decorators: [{
567
595
  type: Component,
568
- args: [{ selector: 'ax-image-editor-view', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, imports: [AXButtonComponent], template: "<canvas\n tabindex=\"1\"\n (mousedown)=\"mouseDownHandler($event)\"\n (mouseup)=\"mouseUpHandler()\"\n (mousemove)=\"mouseMoveHandler($event)\"\n (touchstart)=\"touchStartHandler($event)\"\n (touchend)=\"touchEndHandler()\"\n (touchmove)=\"touchMoveHandler($event)\"\n class=\"ax-canvas-element\"\n #canvasElem\n></canvas>\n<ax-button\n (click)=\"cropButtonHandler()\"\n [style]=\"{ display: service.cropState().state ? 'block' : 'none' }\"\n class=\"ax-crop-save ax-sm\"\n text=\"Crop\"\n></ax-button>\n", styles: ["ax-image-editor-view{position:relative;display:flex;justify-content:center;align-items:center;background-color:#fff;width:100%}ax-image-editor-view .ax-canvas-element{cursor:crosshair}ax-image-editor-view .ax-crop-save{position:absolute;top:0;right:0;margin:1rem}\n"] }]
596
+ args: [{ selector: 'ax-image-editor-view', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<canvas\n tabindex=\"1\"\n (mousedown)=\"mouseDownHandler($event)\"\n (mouseup)=\"mouseUpHandler()\"\n (mousemove)=\"mouseMoveHandler($event)\"\n (touchstart)=\"touchStartHandler($event)\"\n (touchend)=\"touchEndHandler()\"\n (touchmove)=\"touchMoveHandler($event)\"\n class=\"ax-canvas-element\"\n #canvasElem\n></canvas>\n", styles: ["ax-image-editor-view{position:relative;display:flex;justify-content:center;align-items:center;background-color:#fff;width:100%}ax-image-editor-view .ax-canvas-element{cursor:crosshair}ax-image-editor-view .ax-crop-save{position:absolute;top:0;right:0;margin:1rem}\n"] }]
569
597
  }], ctorParameters: () => [], propDecorators: { __hostStyle: [{
570
598
  type: HostBinding,
571
599
  args: ['style']
572
600
  }] } });
573
601
 
602
+ /**
603
+ * paint container.
604
+ * @category Components
605
+ */
606
+ class AXImageEditorContainerComponent extends classes((MXInputBaseValueComponent), MXLookComponent) {
607
+ constructor() {
608
+ super(...arguments);
609
+ /** @ignore */
610
+ this.service = inject(AXImageEditorService);
611
+ this.imageEditorContainer = viewChild('f');
612
+ this.view = contentChild(AXImageEditorViewComponent);
613
+ /** @ignore */
614
+ this.dialogService = inject(AXDialogService);
615
+ /** @ignore */
616
+ this.options = signal({
617
+ color: 'primary',
618
+ title: 'Attention',
619
+ vertical: false,
620
+ content: 'Do you want to save changes?',
621
+ orientation: 'vertical',
622
+ draggable: true,
623
+ });
624
+ }
625
+ save() {
626
+ if (this.service.initialImage() !== this.service.newImage()) {
627
+ this.dialogService
628
+ .confirm(this.options().title, this.options().content, this.options().color, this.options().orientation, this.options().draggable)
629
+ .then((data) => {
630
+ if (data.result) {
631
+ this.service.initialImage.set(this.service.newImage());
632
+ this.commitValue(this.service.imageBlob(), true);
633
+ }
634
+ })
635
+ .catch(() => this.commitValue(null));
636
+ }
637
+ else {
638
+ this.commitValue(null);
639
+ }
640
+ }
641
+ cropButtonHandler() {
642
+ this.view().cropButtonHandler();
643
+ }
644
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorContainerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
645
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.1.8", type: AXImageEditorContainerComponent, isStandalone: true, selector: "ax-image-editor-container", inputs: { look: "look" }, outputs: { onValueChanged: "onValueChanged" }, providers: [
646
+ AXImageEditorService,
647
+ { provide: AXComponent, useExisting: AXImageEditorContainerComponent },
648
+ { provide: AXFocusableComponent, useExisting: AXImageEditorContainerComponent },
649
+ { provide: AXClearableComponent, useExisting: AXImageEditorContainerComponent },
650
+ { provide: AXValuableComponent, useExisting: AXImageEditorContainerComponent },
651
+ {
652
+ provide: NG_VALUE_ACCESSOR,
653
+ useExisting: forwardRef(() => AXImageEditorContainerComponent),
654
+ multi: true,
655
+ },
656
+ ], queries: [{ propertyName: "view", first: true, predicate: AXImageEditorViewComponent, descendants: true, isSignal: true }], viewQueries: [{ propertyName: "imageEditorContainer", first: true, predicate: ["f"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "@if (service.isImageLoad()) {\n <div #f class=\"ax-editor-container ax-{{ look }}\">\n <ax-image-editor-header></ax-image-editor-header>\n\n <ng-content select=\"ax-image-editor-view\"> </ng-content>\n\n @if (service.activeToolState()) {\n <ax-toolbar class=\"ax-secondary-toolbar\">\n <ax-prefix>\n @switch (service.activeToolState()) {\n @case ('pen') {\n <ax-image-editor-pen></ax-image-editor-pen>\n }\n @case ('crop') {\n <ax-image-editor-crop (cropPressed)=\"cropButtonHandler()\"></ax-image-editor-crop>\n }\n @case ('highlight') {\n <ax-image-editor-highlight></ax-image-editor-highlight>\n }\n @case ('rotate') {\n <ax-image-editor-rotate></ax-image-editor-rotate>\n }\n }\n </ax-prefix>\n </ax-toolbar>\n }\n\n <ax-toolbar class=\"ax-main-toolbar\">\n <ax-content>\n <ax-image-editor-tool-selector></ax-image-editor-tool-selector>\n </ax-content>\n </ax-toolbar>\n </div>\n <div class=\"ax-error-container\"></div>\n} @else {\n <div class=\"ax-loading-spinner-container\">\n <ax-loading-spinner [size]=\"16\" color=\"primary\" text=\"Loading Image ...\"></ax-loading-spinner>\n </div>\n}\n<ng-content select=\"ax-validation-rule\"> </ng-content>\n", styles: ["ax-image-editor-container{width:fit-content;display:block}ax-image-editor-container>.ax-editor-container{display:block;height:auto!important;--ax-comp-editor-space-start-size: 0;--ax-comp-editor-space-end-size: 0}ax-image-editor-container .ax-loading-spinner-container{display:flex;justify-content:center;align-items:center}ax-image-editor-container .ax-main-toolbar{justify-content:center;padding:.2rem}ax-image-editor-container .ax-secondary-toolbar{padding:.2rem;border-bottom:1px solid rgba(var(--ax-sys-color-border-surface));justify-content:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: AXDecoratorModule }, { kind: "component", type: i1.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-subtitle, ax-placeholder, ax-overlay" }, { kind: "component", type: AXLoadingSpinnerComponent, selector: "ax-loading-spinner", inputs: ["text", "color", "size", "stroke"] }, { kind: "ngmodule", type: AXToolBarModule }, { kind: "component", type: i2.AXToolBarComponent, selector: "ax-toolbar" }, { kind: "component", type: AXImageEditorCropComponent, selector: "ax-image-editor-crop", outputs: ["cropPressed"] }, { kind: "ngmodule", type: AXButtonModule }, { kind: "component", type: AXImageEditorToolSelectorComponent, selector: "ax-image-editor-tool-selector" }, { kind: "component", type: AXImageEditorPenComponent, selector: "ax-image-editor-pen" }, { kind: "component", type: AXImageEditorHighlightComponent, selector: "ax-image-editor-highlight" }, { kind: "component", type: AXImageEditorRotateComponent, selector: "ax-image-editor-rotate" }, { kind: "component", type: AXimageEditorHeaderComponent, selector: "ax-image-editor-header" }], encapsulation: i0.ViewEncapsulation.None }); }
657
+ }
658
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorContainerComponent, decorators: [{
659
+ type: Component,
660
+ args: [{ selector: 'ax-image-editor-container', encapsulation: ViewEncapsulation.None, outputs: ['onValueChanged'], inputs: ['look'], providers: [
661
+ AXImageEditorService,
662
+ { provide: AXComponent, useExisting: AXImageEditorContainerComponent },
663
+ { provide: AXFocusableComponent, useExisting: AXImageEditorContainerComponent },
664
+ { provide: AXClearableComponent, useExisting: AXImageEditorContainerComponent },
665
+ { provide: AXValuableComponent, useExisting: AXImageEditorContainerComponent },
666
+ {
667
+ provide: NG_VALUE_ACCESSOR,
668
+ useExisting: forwardRef(() => AXImageEditorContainerComponent),
669
+ multi: true,
670
+ },
671
+ ], imports: [
672
+ CommonModule,
673
+ AXDecoratorModule,
674
+ AXLoadingSpinnerComponent,
675
+ AXToolBarModule,
676
+ AXImageEditorCropComponent,
677
+ AXButtonModule,
678
+ AXImageEditorToolSelectorComponent,
679
+ AXImageEditorPenComponent,
680
+ AXImageEditorHighlightComponent,
681
+ AXImageEditorRotateComponent,
682
+ AXimageEditorHeaderComponent,
683
+ ], template: "@if (service.isImageLoad()) {\n <div #f class=\"ax-editor-container ax-{{ look }}\">\n <ax-image-editor-header></ax-image-editor-header>\n\n <ng-content select=\"ax-image-editor-view\"> </ng-content>\n\n @if (service.activeToolState()) {\n <ax-toolbar class=\"ax-secondary-toolbar\">\n <ax-prefix>\n @switch (service.activeToolState()) {\n @case ('pen') {\n <ax-image-editor-pen></ax-image-editor-pen>\n }\n @case ('crop') {\n <ax-image-editor-crop (cropPressed)=\"cropButtonHandler()\"></ax-image-editor-crop>\n }\n @case ('highlight') {\n <ax-image-editor-highlight></ax-image-editor-highlight>\n }\n @case ('rotate') {\n <ax-image-editor-rotate></ax-image-editor-rotate>\n }\n }\n </ax-prefix>\n </ax-toolbar>\n }\n\n <ax-toolbar class=\"ax-main-toolbar\">\n <ax-content>\n <ax-image-editor-tool-selector></ax-image-editor-tool-selector>\n </ax-content>\n </ax-toolbar>\n </div>\n <div class=\"ax-error-container\"></div>\n} @else {\n <div class=\"ax-loading-spinner-container\">\n <ax-loading-spinner [size]=\"16\" color=\"primary\" text=\"Loading Image ...\"></ax-loading-spinner>\n </div>\n}\n<ng-content select=\"ax-validation-rule\"> </ng-content>\n", styles: ["ax-image-editor-container{width:fit-content;display:block}ax-image-editor-container>.ax-editor-container{display:block;height:auto!important;--ax-comp-editor-space-start-size: 0;--ax-comp-editor-space-end-size: 0}ax-image-editor-container .ax-loading-spinner-container{display:flex;justify-content:center;align-items:center}ax-image-editor-container .ax-main-toolbar{justify-content:center;padding:.2rem}ax-image-editor-container .ax-secondary-toolbar{padding:.2rem;border-bottom:1px solid rgba(var(--ax-sys-color-border-surface));justify-content:center}\n"] }]
684
+ }] });
685
+
574
686
  const COMPONENT = [
575
- AXImageEditorColorPickerComponent,
576
- AXImageEditorPenModeChangerComponent,
577
687
  AXImageEditorViewComponent,
578
688
  AXImageEditorContainerComponent,
579
689
  AXImageEditorCropComponent,
690
+ AXImageEditorHistoryComponent,
691
+ AXImageEditorToolSelectorComponent,
692
+ AXImageEditorPenComponent,
693
+ AXImageEditorHighlightComponent,
694
+ AXImageEditorRotateComponent,
695
+ AXimageEditorHeaderComponent,
580
696
  ];
581
697
  const MODULES = [
582
698
  AXButtonModule,
@@ -591,8 +707,8 @@ const MODULES = [
591
707
  AXTooltipModule,
592
708
  ];
593
709
  class AXImageEditorModule {
594
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
595
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorModule, imports: [AXButtonModule,
710
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
711
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorModule, imports: [AXButtonModule,
596
712
  FormsModule,
597
713
  AXRangeSliderModule,
598
714
  AXSelectBoxModule,
@@ -601,18 +717,33 @@ class AXImageEditorModule {
601
717
  AXDecoratorModule,
602
718
  AXLoadingModule,
603
719
  AXDialogModule,
604
- AXTooltipModule, AXImageEditorColorPickerComponent,
605
- AXImageEditorPenModeChangerComponent,
606
- AXImageEditorViewComponent,
720
+ AXTooltipModule, AXImageEditorViewComponent,
607
721
  AXImageEditorContainerComponent,
608
- AXImageEditorCropComponent], exports: [AXImageEditorColorPickerComponent,
609
- AXImageEditorPenModeChangerComponent,
610
- AXImageEditorViewComponent,
722
+ AXImageEditorCropComponent,
723
+ AXImageEditorHistoryComponent,
724
+ AXImageEditorToolSelectorComponent,
725
+ AXImageEditorPenComponent,
726
+ AXImageEditorHighlightComponent,
727
+ AXImageEditorRotateComponent,
728
+ AXimageEditorHeaderComponent], exports: [AXImageEditorViewComponent,
611
729
  AXImageEditorContainerComponent,
612
- AXImageEditorCropComponent] }); }
613
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorModule, imports: [MODULES, COMPONENT] }); }
730
+ AXImageEditorCropComponent,
731
+ AXImageEditorHistoryComponent,
732
+ AXImageEditorToolSelectorComponent,
733
+ AXImageEditorPenComponent,
734
+ AXImageEditorHighlightComponent,
735
+ AXImageEditorRotateComponent,
736
+ AXimageEditorHeaderComponent] }); }
737
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorModule, imports: [MODULES, AXImageEditorContainerComponent,
738
+ AXImageEditorCropComponent,
739
+ AXImageEditorHistoryComponent,
740
+ AXImageEditorToolSelectorComponent,
741
+ AXImageEditorPenComponent,
742
+ AXImageEditorHighlightComponent,
743
+ AXImageEditorRotateComponent,
744
+ AXimageEditorHeaderComponent] }); }
614
745
  }
615
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.7", ngImport: i0, type: AXImageEditorModule, decorators: [{
746
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.8", ngImport: i0, type: AXImageEditorModule, decorators: [{
616
747
  type: NgModule,
617
748
  args: [{
618
749
  imports: [...MODULES, ...COMPONENT],
@@ -625,5 +756,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.1.7", ngImpor
625
756
  * Generated bundle index. Do not edit.
626
757
  */
627
758
 
628
- export { AXImageEditorColorPickerComponent, AXImageEditorContainerComponent, AXImageEditorCropComponent, AXImageEditorModule, AXImageEditorPenModeChangerComponent, AXImageEditorViewComponent };
759
+ export { AXImageEditorContainerComponent, AXImageEditorCropComponent, AXImageEditorHighlightComponent, AXImageEditorHistoryComponent, AXImageEditorModule, AXImageEditorPenComponent, AXImageEditorRotateComponent, AXImageEditorService, AXImageEditorToolSelectorComponent, AXImageEditorViewComponent, AXimageEditorHeaderComponent };
629
760
  //# sourceMappingURL=acorex-components-image-editor.mjs.map