tui-image-editor-angular3 14.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +155 -0
- package/esm2020/lib/consts.mjs +170 -0
- package/esm2020/lib/i18n/en.mjs +129 -0
- package/esm2020/lib/i18n/nl.mjs +128 -0
- package/esm2020/lib/i18n/translation.service.mjs +40 -0
- package/esm2020/lib/interfaces/command.mjs +2 -0
- package/esm2020/lib/interfaces/history-item.mjs +343 -0
- package/esm2020/lib/interfaces/image-size.mjs +2 -0
- package/esm2020/lib/interfaces/tools-config.mjs +2 -0
- package/esm2020/lib/menus/buttons/crop/crop.component.mjs +22 -0
- package/esm2020/lib/menus/buttons/delete/delete.component.mjs +40 -0
- package/esm2020/lib/menus/buttons/delete-all/delete-all.component.mjs +27 -0
- package/esm2020/lib/menus/buttons/download/download.component.mjs +40 -0
- package/esm2020/lib/menus/buttons/drag/drag.component.mjs +41 -0
- package/esm2020/lib/menus/buttons/draw/draw.component.mjs +22 -0
- package/esm2020/lib/menus/buttons/filter/filter.component.mjs +22 -0
- package/esm2020/lib/menus/buttons/flip/flip.component.mjs +22 -0
- package/esm2020/lib/menus/buttons/history/history.component.mjs +41 -0
- package/esm2020/lib/menus/buttons/icon/icon.component.mjs +22 -0
- package/esm2020/lib/menus/buttons/load/load.component.mjs +23 -0
- package/esm2020/lib/menus/buttons/mask/mask.component.mjs +22 -0
- package/esm2020/lib/menus/buttons/redo/redo.component.mjs +36 -0
- package/esm2020/lib/menus/buttons/reset/reset.component.mjs +28 -0
- package/esm2020/lib/menus/buttons/rotate/rotate.component.mjs +22 -0
- package/esm2020/lib/menus/buttons/shape/shape.component.mjs +22 -0
- package/esm2020/lib/menus/buttons/text/text.component.mjs +22 -0
- package/esm2020/lib/menus/buttons/undo/undo.component.mjs +36 -0
- package/esm2020/lib/menus/buttons/zoom-in/zoom-in.component.mjs +45 -0
- package/esm2020/lib/menus/buttons/zoom-out/zoom-out.component.mjs +20 -0
- package/esm2020/lib/services/history.service.mjs +86 -0
- package/esm2020/lib/services/tools.config-manager.service.mjs +45 -0
- package/esm2020/lib/submenus/crop/crop.component.mjs +76 -0
- package/esm2020/lib/submenus/draw/draw.component.mjs +149 -0
- package/esm2020/lib/submenus/filter/filter.component.mjs +345 -0
- package/esm2020/lib/submenus/flip/flip.component.mjs +39 -0
- package/esm2020/lib/submenus/icon/icon.component.mjs +119 -0
- package/esm2020/lib/submenus/mask/mask.component.mjs +69 -0
- package/esm2020/lib/submenus/rotate/rotate.component.mjs +57 -0
- package/esm2020/lib/submenus/shape/shape.component.mjs +163 -0
- package/esm2020/lib/submenus/text/text.component.mjs +175 -0
- package/esm2020/lib/svg-definitions/svg-definitions.component.mjs +12 -0
- package/esm2020/lib/tui-image-editor.component.mjs +294 -0
- package/esm2020/lib/tui-image-editor.module.mjs +136 -0
- package/esm2020/lib/utils.mjs +173 -0
- package/esm2020/public-api.mjs +8 -0
- package/esm2020/tui-image-editor-angular2.mjs +5 -0
- package/esm2020/tui-image-editor-angular3.mjs +5 -0
- package/fesm2015/tui-image-editor-angular2.mjs +3166 -0
- package/fesm2015/tui-image-editor-angular2.mjs.map +1 -0
- package/fesm2015/tui-image-editor-angular3.mjs +3166 -0
- package/fesm2015/tui-image-editor-angular3.mjs.map +1 -0
- package/fesm2020/tui-image-editor-angular2.mjs +3126 -0
- package/fesm2020/tui-image-editor-angular2.mjs.map +1 -0
- package/fesm2020/tui-image-editor-angular3.mjs +3126 -0
- package/fesm2020/tui-image-editor-angular3.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/consts.d.ts +144 -0
- package/lib/consts.d.ts.map +1 -0
- package/lib/i18n/en.d.ts +128 -0
- package/lib/i18n/en.d.ts.map +1 -0
- package/lib/i18n/nl.d.ts +127 -0
- package/lib/i18n/nl.d.ts.map +1 -0
- package/lib/i18n/translation.service.d.ts +14 -0
- package/lib/i18n/translation.service.d.ts.map +1 -0
- package/lib/interfaces/command.d.ts +4 -0
- package/lib/interfaces/command.d.ts.map +1 -0
- package/lib/interfaces/history-item.d.ts +26 -0
- package/lib/interfaces/history-item.d.ts.map +1 -0
- package/lib/interfaces/image-size.d.ts +6 -0
- package/lib/interfaces/image-size.d.ts.map +1 -0
- package/lib/interfaces/tools-config.d.ts +14 -0
- package/lib/interfaces/tools-config.d.ts.map +1 -0
- package/lib/menus/buttons/crop/crop.component.d.ts +10 -0
- package/lib/menus/buttons/crop/crop.component.d.ts.map +1 -0
- package/lib/menus/buttons/delete/delete.component.d.ts +13 -0
- package/lib/menus/buttons/delete/delete.component.d.ts.map +1 -0
- package/lib/menus/buttons/delete-all/delete-all.component.d.ts +11 -0
- package/lib/menus/buttons/delete-all/delete-all.component.d.ts.map +1 -0
- package/lib/menus/buttons/download/download.component.d.ts +9 -0
- package/lib/menus/buttons/download/download.component.d.ts.map +1 -0
- package/lib/menus/buttons/drag/drag.component.d.ts +11 -0
- package/lib/menus/buttons/drag/drag.component.d.ts.map +1 -0
- package/lib/menus/buttons/draw/draw.component.d.ts +10 -0
- package/lib/menus/buttons/draw/draw.component.d.ts.map +1 -0
- package/lib/menus/buttons/filter/filter.component.d.ts +10 -0
- package/lib/menus/buttons/filter/filter.component.d.ts.map +1 -0
- package/lib/menus/buttons/flip/flip.component.d.ts +10 -0
- package/lib/menus/buttons/flip/flip.component.d.ts.map +1 -0
- package/lib/menus/buttons/history/history.component.d.ts +13 -0
- package/lib/menus/buttons/history/history.component.d.ts.map +1 -0
- package/lib/menus/buttons/icon/icon.component.d.ts +10 -0
- package/lib/menus/buttons/icon/icon.component.d.ts.map +1 -0
- package/lib/menus/buttons/load/load.component.d.ts +9 -0
- package/lib/menus/buttons/load/load.component.d.ts.map +1 -0
- package/lib/menus/buttons/mask/mask.component.d.ts +10 -0
- package/lib/menus/buttons/mask/mask.component.d.ts.map +1 -0
- package/lib/menus/buttons/redo/redo.component.d.ts +12 -0
- package/lib/menus/buttons/redo/redo.component.d.ts.map +1 -0
- package/lib/menus/buttons/reset/reset.component.d.ts +12 -0
- package/lib/menus/buttons/reset/reset.component.d.ts.map +1 -0
- package/lib/menus/buttons/rotate/rotate.component.d.ts +10 -0
- package/lib/menus/buttons/rotate/rotate.component.d.ts.map +1 -0
- package/lib/menus/buttons/shape/shape.component.d.ts +10 -0
- package/lib/menus/buttons/shape/shape.component.d.ts.map +1 -0
- package/lib/menus/buttons/text/text.component.d.ts +10 -0
- package/lib/menus/buttons/text/text.component.d.ts.map +1 -0
- package/lib/menus/buttons/undo/undo.component.d.ts +12 -0
- package/lib/menus/buttons/undo/undo.component.d.ts.map +1 -0
- package/lib/menus/buttons/zoom-in/zoom-in.component.d.ts +12 -0
- package/lib/menus/buttons/zoom-in/zoom-in.component.d.ts.map +1 -0
- package/lib/menus/buttons/zoom-out/zoom-out.component.d.ts +9 -0
- package/lib/menus/buttons/zoom-out/zoom-out.component.d.ts.map +1 -0
- package/lib/services/history.service.d.ts +45 -0
- package/lib/services/history.service.d.ts.map +1 -0
- package/lib/services/tools.config-manager.service.d.ts +12 -0
- package/lib/services/tools.config-manager.service.d.ts.map +1 -0
- package/lib/submenus/crop/crop.component.d.ts +23 -0
- package/lib/submenus/crop/crop.component.d.ts.map +1 -0
- package/lib/submenus/draw/draw.component.d.ts +32 -0
- package/lib/submenus/draw/draw.component.d.ts.map +1 -0
- package/lib/submenus/filter/filter.component.d.ts +70 -0
- package/lib/submenus/filter/filter.component.d.ts.map +1 -0
- package/lib/submenus/flip/flip.component.d.ts +10 -0
- package/lib/submenus/flip/flip.component.d.ts.map +1 -0
- package/lib/submenus/icon/icon.component.d.ts +24 -0
- package/lib/submenus/icon/icon.component.d.ts.map +1 -0
- package/lib/submenus/mask/mask.component.d.ts +16 -0
- package/lib/submenus/mask/mask.component.d.ts.map +1 -0
- package/lib/submenus/rotate/rotate.component.d.ts +12 -0
- package/lib/submenus/rotate/rotate.component.d.ts.map +1 -0
- package/lib/submenus/shape/shape.component.d.ts +31 -0
- package/lib/submenus/shape/shape.component.d.ts.map +1 -0
- package/lib/submenus/text/text.component.d.ts +31 -0
- package/lib/submenus/text/text.component.d.ts.map +1 -0
- package/lib/svg-definitions/svg-definitions.component.d.ts +6 -0
- package/lib/svg-definitions/svg-definitions.component.d.ts.map +1 -0
- package/lib/tui-image-editor.component.d.ts +71 -0
- package/lib/tui-image-editor.component.d.ts.map +1 -0
- package/lib/tui-image-editor.module.d.ts +48 -0
- package/lib/tui-image-editor.module.d.ts.map +1 -0
- package/lib/utils.d.ts +45 -0
- package/lib/utils.d.ts.map +1 -0
- package/package.json +43 -0
- package/public-api.d.ts +4 -0
- package/public-api.d.ts.map +1 -0
- package/src/checkboxes.scss +95 -0
- package/src/theme.scss +936 -0
- package/tui-image-editor-angular2.d.ts.map +1 -0
|
@@ -0,0 +1,345 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { defaultColors, filterType } from '../../consts';
|
|
3
|
+
import { HistoryItemType } from '../../interfaces/history-item';
|
|
4
|
+
import { removeFilter, rgbaToObject } from '../../utils';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../services/history.service";
|
|
7
|
+
import * as i2 from "@angular/forms";
|
|
8
|
+
import * as i3 from "ngx-color-picker";
|
|
9
|
+
import * as i4 from "@ngx-translate/core";
|
|
10
|
+
export class FilterComponent {
|
|
11
|
+
constructor(historyService) {
|
|
12
|
+
this.historyService = historyService;
|
|
13
|
+
this.filterBlurChecked = false;
|
|
14
|
+
this.filterBlurValue = 0.1;
|
|
15
|
+
this.filterGrayscaleChecked = false;
|
|
16
|
+
this.filterSepiaChecked = false;
|
|
17
|
+
this.filterEmbossChecked = false;
|
|
18
|
+
this.filterInvertChecked = false;
|
|
19
|
+
this.filterVintageChecked = false;
|
|
20
|
+
this.filterSharpenChecked = false;
|
|
21
|
+
this.filterWhiteRemovalChecked = false;
|
|
22
|
+
this.filterWhiteRemovalDistance = 0.5;
|
|
23
|
+
this.filterBrightnessChecked = false;
|
|
24
|
+
this.filterBrightnessValue = 0;
|
|
25
|
+
this.filterNoiseChecked = false;
|
|
26
|
+
this.filterNoiseValue = 100;
|
|
27
|
+
this.filterPixelateChecked = false;
|
|
28
|
+
this.filterPixelateValue = 15;
|
|
29
|
+
this.filterColorFilterChecked = false;
|
|
30
|
+
this.filterColorFilterThreshold = 0;
|
|
31
|
+
this.defaultFilterTintColors = defaultColors;
|
|
32
|
+
this.filterTintChecked = false;
|
|
33
|
+
this.filterTintColor = 'rgba(3, 189, 158, 0.7)';
|
|
34
|
+
this.defaultFilterMultiplyColors = defaultColors;
|
|
35
|
+
this.filterMultiplyChecked = false;
|
|
36
|
+
this.filterMultiplyColor = 'rgb(81, 92, 230)';
|
|
37
|
+
this.defaultFilterBlendColors = defaultColors;
|
|
38
|
+
this.filterBlendChecked = false;
|
|
39
|
+
this.filterBlendColor = 'rgba(255, 187, 59, 1)';
|
|
40
|
+
}
|
|
41
|
+
ngOnInit() {
|
|
42
|
+
this.historyServiceSubscription = this.historyService.onChangeEmitter.subscribe((items) => items != null && items.length != 0
|
|
43
|
+
? this.rebindFields(items)
|
|
44
|
+
: this.rebindFields(this.historyService.items));
|
|
45
|
+
}
|
|
46
|
+
ngOnDestroy() {
|
|
47
|
+
this.historyServiceSubscription?.unsubscribe();
|
|
48
|
+
}
|
|
49
|
+
rebindFields(items) {
|
|
50
|
+
console.debug(items);
|
|
51
|
+
if (this.imageEditor != null) {
|
|
52
|
+
this.filterBlurChecked = this.imageEditor.hasFilter('blur');
|
|
53
|
+
this.filterBrightnessChecked = this.imageEditor.hasFilter('brightness');
|
|
54
|
+
if (this.filterBrightnessChecked) {
|
|
55
|
+
this.filterBrightnessValue = this.getAppliedFilterArgument(items, filterType.BRIGHTNESS, 0);
|
|
56
|
+
}
|
|
57
|
+
this.filterColorFilterChecked =
|
|
58
|
+
this.imageEditor.hasFilter('removeColor') &&
|
|
59
|
+
this.hasAppliedFilter(items, filterType.REMOVE_COLOR);
|
|
60
|
+
if (this.filterColorFilterChecked) {
|
|
61
|
+
this.filterColorFilterThreshold = this.getAppliedFilterArgument(items, filterType.REMOVE_COLOR, 0);
|
|
62
|
+
}
|
|
63
|
+
this.filterEmbossChecked = this.imageEditor.hasFilter('emboss');
|
|
64
|
+
this.filterGrayscaleChecked = this.imageEditor.hasFilter('grayscale');
|
|
65
|
+
this.filterInvertChecked = this.imageEditor.hasFilter('invert');
|
|
66
|
+
this.filterNoiseChecked = this.imageEditor.hasFilter('noise');
|
|
67
|
+
if (this.filterNoiseChecked) {
|
|
68
|
+
this.filterNoiseValue = this.getAppliedFilterArgument(items, filterType.NOISE, 0);
|
|
69
|
+
}
|
|
70
|
+
this.filterPixelateChecked = this.imageEditor.hasFilter('pixelate');
|
|
71
|
+
if (this.filterPixelateChecked) {
|
|
72
|
+
this.filterPixelateValue = this.getAppliedFilterArgument(items, filterType.PIXELATE, 0);
|
|
73
|
+
}
|
|
74
|
+
this.filterSepiaChecked = this.imageEditor.hasFilter('sepia');
|
|
75
|
+
this.filterSharpenChecked = this.imageEditor.hasFilter('sharpen');
|
|
76
|
+
this.filterVintageChecked = this.imageEditor.hasFilter('vintage');
|
|
77
|
+
this.filterWhiteRemovalChecked =
|
|
78
|
+
this.imageEditor.hasFilter('removeColor') &&
|
|
79
|
+
this.hasAppliedFilter(items, filterType.REMOVE_WHITE);
|
|
80
|
+
if (this.filterWhiteRemovalChecked) {
|
|
81
|
+
this.filterWhiteRemovalDistance = this.getAppliedFilterArgument(items, filterType.REMOVE_WHITE, 0);
|
|
82
|
+
}
|
|
83
|
+
this.filterMultiplyChecked =
|
|
84
|
+
this.imageEditor.hasFilter('blendColor') &&
|
|
85
|
+
this.hasAppliedFilter(items, filterType.MULTIPLY);
|
|
86
|
+
if (this.filterMultiplyChecked) {
|
|
87
|
+
this.filterMultiplyColor = this.getAppliedFilterArgument(items, filterType.MULTIPLY, 0);
|
|
88
|
+
}
|
|
89
|
+
this.filterTintChecked =
|
|
90
|
+
this.imageEditor.hasFilter('blendColor') &&
|
|
91
|
+
this.hasAppliedFilter(items, filterType.TINT);
|
|
92
|
+
if (this.filterTintChecked) {
|
|
93
|
+
this.filterTintColor = this.getAppliedFilterArgument(items, filterType.TINT, 0);
|
|
94
|
+
}
|
|
95
|
+
this.filterBlendChecked =
|
|
96
|
+
this.imageEditor.hasFilter('blendColor') &&
|
|
97
|
+
this.hasAppliedFilter(items, filterType.BLEND);
|
|
98
|
+
if (this.filterBlendChecked) {
|
|
99
|
+
this.filterBlendColor = this.getAppliedFilterArgument(items, filterType.BLEND, 0);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
getAppliedFilterArgument(items, type, index) {
|
|
104
|
+
let validItems = items.filter((f) => f.filterType === type && f.type === HistoryItemType.ApplyFilter);
|
|
105
|
+
return validItems[validItems.length - 1].args[index];
|
|
106
|
+
}
|
|
107
|
+
hasAppliedFilter(historyItems, type) {
|
|
108
|
+
let hasFilter = false;
|
|
109
|
+
for (let i = 0; i < historyItems.length; i++) {
|
|
110
|
+
let item = historyItems[i];
|
|
111
|
+
if (item.type === HistoryItemType.ApplyFilter &&
|
|
112
|
+
item.filterType === type) {
|
|
113
|
+
hasFilter = true;
|
|
114
|
+
}
|
|
115
|
+
else if (hasFilter == true &&
|
|
116
|
+
[filterType.TINT, filterType.BLEND, filterType.MULTIPLY].some((t) => t === type) &&
|
|
117
|
+
item.type === HistoryItemType.RemoveFilter &&
|
|
118
|
+
item.filterType === filterType.BLEND_OR_TINT_OR_MULTIPLY) {
|
|
119
|
+
hasFilter = false;
|
|
120
|
+
}
|
|
121
|
+
else if (hasFilter == true &&
|
|
122
|
+
[filterType.REMOVE_COLOR, filterType.REMOVE_WHITE].some((t) => t === type) &&
|
|
123
|
+
item.type === HistoryItemType.RemoveFilter &&
|
|
124
|
+
item.filterType === filterType.REMOVE_COLOR_OR_WHITE) {
|
|
125
|
+
hasFilter = false;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
return hasFilter;
|
|
129
|
+
}
|
|
130
|
+
filterWhiteRemovalCheckedChanged(newValue) {
|
|
131
|
+
this.filterApply('white-removal');
|
|
132
|
+
}
|
|
133
|
+
filterWhiteRemovalDistanceChanged(newValue, isSilent) {
|
|
134
|
+
this.filterApply('white-removal', isSilent);
|
|
135
|
+
}
|
|
136
|
+
filterBrightnessCheckedChanged(newValue) {
|
|
137
|
+
this.filterApply('brightness');
|
|
138
|
+
}
|
|
139
|
+
filterBrightnessValueChanged(newValue, isSilent) {
|
|
140
|
+
this.filterApply('brightness', isSilent);
|
|
141
|
+
}
|
|
142
|
+
filterNoiseCheckedChanged(newValue) {
|
|
143
|
+
this.filterApply('noise');
|
|
144
|
+
}
|
|
145
|
+
filterNoiseValueChanged(newValue, isSilent) {
|
|
146
|
+
this.filterApply('noise', isSilent);
|
|
147
|
+
}
|
|
148
|
+
filterPixelateCheckedChanged(newValue) {
|
|
149
|
+
this.filterApply('pixelate');
|
|
150
|
+
}
|
|
151
|
+
filterPixelateValueChanged(newValue, isSilent) {
|
|
152
|
+
this.filterApply('pixelate', isSilent);
|
|
153
|
+
}
|
|
154
|
+
filterColorFilterCheckedChanged(newValue) {
|
|
155
|
+
this.filterApply('removeColor');
|
|
156
|
+
}
|
|
157
|
+
filterColorFilterThresholdChanged(newValue, isSilent) {
|
|
158
|
+
this.filterApply('removeColor', isSilent);
|
|
159
|
+
}
|
|
160
|
+
filterTintColorChanged(newColor) {
|
|
161
|
+
this.filterApply('tint');
|
|
162
|
+
}
|
|
163
|
+
filterTintCheckedChanged(newValue) {
|
|
164
|
+
this.filterApply('tint');
|
|
165
|
+
if (this.filterTintChecked) {
|
|
166
|
+
this.filterMultiplyChecked = false;
|
|
167
|
+
this.filterBlendChecked = false;
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
filterMultiplyColorChanged(newColor) {
|
|
171
|
+
this.filterApply('multiply');
|
|
172
|
+
}
|
|
173
|
+
filterMultiplyCheckedChanged(newValue) {
|
|
174
|
+
this.filterApply('multiply');
|
|
175
|
+
if (this.filterMultiplyChecked) {
|
|
176
|
+
this.filterTintChecked = false;
|
|
177
|
+
this.filterBlendChecked = false;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
filterBlendColorChanged(newColor) {
|
|
181
|
+
this.filterApply('blend');
|
|
182
|
+
}
|
|
183
|
+
filterBlendCheckedChanged(newValue) {
|
|
184
|
+
this.filterApply('blend');
|
|
185
|
+
if (this.filterBlendChecked) {
|
|
186
|
+
this.filterMultiplyChecked = false;
|
|
187
|
+
this.filterTintChecked = false;
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
filterBlurCheckedChanged(newValue) {
|
|
191
|
+
this.filterApply('blur');
|
|
192
|
+
}
|
|
193
|
+
filterGrayscaleCheckedChanged(newValue) {
|
|
194
|
+
this.filterApply('grayscale');
|
|
195
|
+
}
|
|
196
|
+
filterSepiaCheckedChanged(newValue) {
|
|
197
|
+
this.filterApply('sepia');
|
|
198
|
+
}
|
|
199
|
+
filterEmbossCheckedChanged(newValue) {
|
|
200
|
+
this.filterApply('emboss');
|
|
201
|
+
}
|
|
202
|
+
filterInvertCheckedChanged(newValue) {
|
|
203
|
+
this.filterApply('invert');
|
|
204
|
+
}
|
|
205
|
+
filterVintageCheckedChanged(newValue) {
|
|
206
|
+
this.filterApply('vintage');
|
|
207
|
+
}
|
|
208
|
+
filterSharpenCheckedChanged(newValue) {
|
|
209
|
+
this.filterApply('sharpen');
|
|
210
|
+
}
|
|
211
|
+
filterApply(type, isSilent = false) {
|
|
212
|
+
switch (type) {
|
|
213
|
+
case 'white-removal':
|
|
214
|
+
this.filterApplyConfirmed(this.filterWhiteRemovalChecked, 'removeColor', {
|
|
215
|
+
color: '#FFFFFF',
|
|
216
|
+
useAlpha: false,
|
|
217
|
+
distance: this.filterWhiteRemovalDistance,
|
|
218
|
+
}, isSilent);
|
|
219
|
+
break;
|
|
220
|
+
case 'brightness':
|
|
221
|
+
this.filterApplyConfirmed(this.filterBrightnessChecked, 'brightness', {
|
|
222
|
+
brightness: this.filterBrightnessValue,
|
|
223
|
+
}, isSilent);
|
|
224
|
+
break;
|
|
225
|
+
case 'noise':
|
|
226
|
+
this.filterApplyConfirmed(this.filterNoiseChecked, 'noise', {
|
|
227
|
+
noise: this.filterNoiseValue,
|
|
228
|
+
}, isSilent);
|
|
229
|
+
break;
|
|
230
|
+
case 'pixelate':
|
|
231
|
+
this.filterApplyConfirmed(this.filterPixelateChecked, 'pixelate', {
|
|
232
|
+
blocksize: this.filterPixelateValue,
|
|
233
|
+
}, isSilent);
|
|
234
|
+
break;
|
|
235
|
+
case 'removeColor':
|
|
236
|
+
this.filterApplyConfirmed(this.filterColorFilterChecked, 'removeColor', {
|
|
237
|
+
color: '#FFFFFF',
|
|
238
|
+
distance: this.filterColorFilterThreshold,
|
|
239
|
+
}, isSilent);
|
|
240
|
+
break;
|
|
241
|
+
case 'blur':
|
|
242
|
+
this.filterApplyConfirmed(this.filterBlurChecked, 'blur', {
|
|
243
|
+
blur: this.filterBlurValue,
|
|
244
|
+
}, isSilent);
|
|
245
|
+
break;
|
|
246
|
+
case 'blend':
|
|
247
|
+
this.filterApplyConfirmed(this.filterBlendChecked, 'blendColor', {
|
|
248
|
+
mode: 'add',
|
|
249
|
+
color: this.filterBlendColor,
|
|
250
|
+
}, isSilent);
|
|
251
|
+
break;
|
|
252
|
+
case 'multiply':
|
|
253
|
+
this.filterApplyConfirmed(this.filterMultiplyChecked, 'blendColor', {
|
|
254
|
+
mode: 'multiply',
|
|
255
|
+
color: this.filterMultiplyColor,
|
|
256
|
+
}, isSilent);
|
|
257
|
+
break;
|
|
258
|
+
case 'tint':
|
|
259
|
+
let rgbTint = rgbaToObject(this.filterTintColor);
|
|
260
|
+
this.filterApplyConfirmed(this.filterTintChecked, 'blendColor', {
|
|
261
|
+
mode: 'tint',
|
|
262
|
+
color: rgbTint.hexString,
|
|
263
|
+
alpha: rgbTint.alpha,
|
|
264
|
+
}, isSilent);
|
|
265
|
+
break;
|
|
266
|
+
case 'grayscale':
|
|
267
|
+
this.filterApplyConfirmed(this.filterGrayscaleChecked, type, {}, isSilent);
|
|
268
|
+
break;
|
|
269
|
+
case 'sepia':
|
|
270
|
+
this.filterApplyConfirmed(this.filterSepiaChecked, type, {}, isSilent);
|
|
271
|
+
break;
|
|
272
|
+
case 'emboss':
|
|
273
|
+
this.filterApplyConfirmed(this.filterEmbossChecked, type, {}, isSilent);
|
|
274
|
+
break;
|
|
275
|
+
case 'invert':
|
|
276
|
+
this.filterApplyConfirmed(this.filterInvertChecked, type, {}, isSilent);
|
|
277
|
+
break;
|
|
278
|
+
case 'vintage':
|
|
279
|
+
this.filterApplyConfirmed(this.filterVintageChecked, type, {}, isSilent);
|
|
280
|
+
break;
|
|
281
|
+
case 'sharpen':
|
|
282
|
+
this.filterApplyConfirmed(this.filterSharpenChecked, type, {}, isSilent);
|
|
283
|
+
break;
|
|
284
|
+
}
|
|
285
|
+
}
|
|
286
|
+
async filterApplyConfirmed(applying, type, options, isSilent = false) {
|
|
287
|
+
let functionToExecute = async () => {
|
|
288
|
+
if (applying) {
|
|
289
|
+
if (type === 'blendColor' && this.imageEditor.hasFilter('blendColor')) {
|
|
290
|
+
switch (options.mode) {
|
|
291
|
+
case 'add':
|
|
292
|
+
this.filterTintChecked = false;
|
|
293
|
+
this.filterMultiplyChecked = false;
|
|
294
|
+
break;
|
|
295
|
+
case 'multiply':
|
|
296
|
+
this.filterTintChecked = false;
|
|
297
|
+
this.filterBlendChecked = false;
|
|
298
|
+
break;
|
|
299
|
+
case 'tint':
|
|
300
|
+
this.filterBlendChecked = false;
|
|
301
|
+
this.filterMultiplyChecked = false;
|
|
302
|
+
break;
|
|
303
|
+
}
|
|
304
|
+
await removeFilter(this.imageEditor, type, isSilent);
|
|
305
|
+
}
|
|
306
|
+
else if (type === 'removeColor' &&
|
|
307
|
+
this.imageEditor.hasFilter('removeColor')) {
|
|
308
|
+
if (options.useAlpha != null) {
|
|
309
|
+
this.filterColorFilterChecked = false;
|
|
310
|
+
}
|
|
311
|
+
else {
|
|
312
|
+
this.filterWhiteRemovalChecked = false;
|
|
313
|
+
}
|
|
314
|
+
await removeFilter(this.imageEditor, type, isSilent);
|
|
315
|
+
}
|
|
316
|
+
await this.imageEditor.applyFilter(type, options, isSilent);
|
|
317
|
+
}
|
|
318
|
+
else if (this.imageEditor.hasFilter(type)) {
|
|
319
|
+
await removeFilter(this.imageEditor, type, isSilent);
|
|
320
|
+
if (type == 'blendColor') {
|
|
321
|
+
this.filterTintChecked = false;
|
|
322
|
+
this.filterMultiplyChecked = false;
|
|
323
|
+
this.filterBlendChecked = false;
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
};
|
|
327
|
+
if (isSilent) {
|
|
328
|
+
await functionToExecute();
|
|
329
|
+
}
|
|
330
|
+
else {
|
|
331
|
+
setTimeout(async () => {
|
|
332
|
+
await functionToExecute();
|
|
333
|
+
});
|
|
334
|
+
}
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
FilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: FilterComponent, deps: [{ token: i1.HistoryService }], target: i0.ɵɵFactoryTarget.Component });
|
|
338
|
+
FilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: FilterComponent, selector: "tui-image-editor-submenus-filter", inputs: { imageEditor: "imageEditor" }, ngImport: i0, template: "<div\r\n class=\"tui-image-editor-menu-filter tui-image-editor-d-flex tui-image-editor-justify-content-center\"\r\n>\r\n <div\r\n class=\"tui-image-editor-submenu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-overflowable-x tui-image-editor-py-3\"\r\n >\r\n <div class=\"tui-image-editor-submenu-align\">\r\n <div\r\n class=\"tui-image-editor-checkbox-wrap fixed-width tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-wrap tui-image-editor-justify-content-center\"\r\n >\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-grayscale\"\r\n [(ngModel)]=\"filterGrayscaleChecked\"\r\n (ngModelChange)=\"filterGrayscaleCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-grayscale\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-invert\"\r\n [(ngModel)]=\"filterInvertChecked\"\r\n (ngModelChange)=\"filterInvertCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-invert\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-sepia\"\r\n [(ngModel)]=\"filterSepiaChecked\"\r\n (ngModelChange)=\"filterSepiaCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-sepia\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-vintage\"\r\n [(ngModel)]=\"filterVintageChecked\"\r\n (ngModelChange)=\"filterVintageCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-sepia2\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-blur\"\r\n [(ngModel)]=\"filterBlurChecked\"\r\n (ngModelChange)=\"filterBlurCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-blur\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-sharpen\"\r\n [(ngModel)]=\"filterSharpenChecked\"\r\n (ngModelChange)=\"filterSharpenCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-sharpen\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-emboss\"\r\n [(ngModel)]=\"filterEmbossChecked\"\r\n (ngModelChange)=\"filterEmbossCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-emboss\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-partition\">\r\n <div></div>\r\n </div>\r\n <div class=\"tui-image-editor-submenu-align\">\r\n <div\r\n class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\"\r\n style=\"margin-bottom: 7px\"\r\n >\r\n <div class=\"tui-image-editor-checkbox-wrap\">\r\n <div class=\"tui-image-editor-checkbox\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-remove-white\"\r\n [(ngModel)]=\"filterWhiteRemovalChecked\"\r\n (ngModelChange)=\"filterWhiteRemovalCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-removeWhite\"\r\n | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n </div>\r\n <div\r\n class=\"tui-image-editor-newline tui-image-editor-range-wrap short tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap tui-image-editor-align-items-center\"\r\n >\r\n <label>{{\r\n \"tui-image-editor-angular-submenus-filter-removeWhite-distance\"\r\n | translate\r\n }}</label>\r\n <input\r\n type=\"range\"\r\n [(ngModel)]=\"filterWhiteRemovalDistance\"\r\n (ngModelChange)=\"filterWhiteRemovalDistanceChanged($event, true)\"\r\n (change)=\"filterWhiteRemovalDistanceChanged($event, false)\"\r\n min=\"0\"\r\n max=\"1\"\r\n step=\"0.001\"\r\n [disabled]=\"filterWhiteRemovalChecked == false\"\r\n />\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\">\r\n <div class=\"tui-image-editor-checkbox\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-brightness\"\r\n [(ngModel)]=\"filterBrightnessChecked\"\r\n (ngModelChange)=\"filterBrightnessCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-brightness\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-range-wrap short tui-image-editor-d-flex tui-image-editor-flex-row align-items-center tui-image-editor-my-2\">\r\n <input\r\n type=\"range\"\r\n [(ngModel)]=\"filterBrightnessValue\"\r\n (ngModelChange)=\"filterBrightnessValueChanged($event, true)\"\r\n (change)=\"filterBrightnessValueChanged($event, false)\"\r\n min=\"-1\"\r\n max=\"1\"\r\n step=\"0.03\"\r\n [disabled]=\"filterBrightnessChecked == false\"\r\n />\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\">\r\n <div class=\"tui-image-editor-checkbox\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-noise\"\r\n [(ngModel)]=\"filterNoiseChecked\"\r\n (ngModelChange)=\"filterNoiseCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-noise\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-range-wrap short tui-image-editor-d-flex tui-image-editor-flex-row align-items-center tui-image-editor-my-2\">\r\n <input\r\n type=\"range\"\r\n [(ngModel)]=\"filterNoiseValue\"\r\n (ngModelChange)=\"filterNoiseValueChanged($event, true)\"\r\n (change)=\"filterNoiseValueChanged($event, false)\"\r\n min=\"0\"\r\n max=\"1000\"\r\n step=\"10\"\r\n [disabled]=\"filterNoiseChecked == false\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-partition only-left-right\">\r\n <div></div>\r\n </div>\r\n <div class=\"tui-image-editor-submenu-align\">\r\n <div class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\">\r\n <div class=\"tui-image-editor-checkbox\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-pixelate\"\r\n [(ngModel)]=\"filterPixelateChecked\"\r\n (ngModelChange)=\"filterPixelateCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-pixelate\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-range-wrap short tui-image-editor-d-flex tui-image-editor-flex-row align-items-center tui-image-editor-my-2\">\r\n <input\r\n type=\"range\"\r\n [(ngModel)]=\"filterPixelateValue\"\r\n (ngModelChange)=\"filterPixelateValueChanged($event, true)\"\r\n (change)=\"filterPixelateValueChanged($event, false)\"\r\n min=\"2\"\r\n max=\"20\"\r\n step=\"1\"\r\n [disabled]=\"filterPixelateChecked == false\"\r\n />\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\">\r\n <div class=\"tui-image-editor-newline tui-image-editor-checkbox-wrap\">\r\n <div class=\"tui-image-editor-checkbox\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-color-filter\"\r\n [(ngModel)]=\"filterColorFilterChecked\"\r\n (ngModelChange)=\"filterColorFilterCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-colorFilter\"\r\n | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-newline tui-image-editor-range-wrap short\">\r\n <label>{{\r\n \"tui-image-editor-angular-submenus-filter-colorFilter-threshold\"\r\n | translate\r\n }}</label>\r\n <div class=\"tie-colorfilter-threshold-range tui-image-editor-range tui-image-editor-d-flex tui-image-editor-flex-row align-items-center tui-image-editor-my-2\">\r\n <input\r\n type=\"range\"\r\n [(ngModel)]=\"filterColorFilterThreshold\"\r\n (ngModelChange)=\"filterColorFilterThresholdChanged($event, true)\"\r\n (change)=\"filterColorFilterThresholdChanged($event, false)\"\r\n min=\"0\"\r\n max=\"1\"\r\n step=\"0.02\"\r\n [disabled]=\"filterColorFilterChecked == false\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-partition\">\r\n <div></div>\r\n </div>\r\n <div\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center\"\r\n >\r\n <div class=\"filter-color-item\">\r\n <div\r\n [class]=\"\r\n 'tie-filter-tint-color tui-image-editor-button tui-image-editor-button-color-picker tui-image-editor-d-flex tui-image-editor-flex-column tui-image-editor-align-items-center ' +\r\n (filterTintChecked ? 'active' : '')\r\n \"\r\n [title]=\"'tui-image-editor-angular-submenus-filter-tint' | translate\"\r\n >\r\n <input\r\n readonly\r\n class=\"tie-filter-tint-color-picker tui-image-editor-mb-2\"\r\n [(colorPicker)]=\"filterTintColor\"\r\n [style.background]=\"filterTintColor\"\r\n [cpOutputFormat]=\"'rgba'\"\r\n [cpPresetColors]=\"defaultFilterTintColors\"\r\n (colorPickerChange)=\"filterTintColorChanged($event)\"\r\n [cpUseRootViewContainer]=\"true\"\r\n />\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-tint\"\r\n [(ngModel)]=\"filterTintChecked\"\r\n (ngModelChange)=\"filterTintCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-tint\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n </div>\r\n <div class=\"filter-color-item\">\r\n <div\r\n [class]=\"\r\n 'tie-filter-multiply-color tui-image-editor-button tui-image-editor-button-color-picker tui-image-editor-d-flex tui-image-editor-flex-column tui-image-editor-align-items-center ' +\r\n (filterMultiplyChecked ? 'active' : '')\r\n \"\r\n [title]=\"\r\n 'tui-image-editor-angular-submenus-filter-multiply' | translate\r\n \"\r\n >\r\n <input\r\n readonly\r\n class=\"tie-filter-multiply-color-picker tui-image-editor-mb-2\"\r\n [(colorPicker)]=\"filterMultiplyColor\"\r\n [style.background]=\"filterMultiplyColor\"\r\n [cpOutputFormat]=\"'hex'\"\r\n [cpPresetColors]=\"defaultFilterMultiplyColors\"\r\n (colorPickerChange)=\"filterMultiplyColorChanged($event)\"\r\n [cpUseRootViewContainer]=\"true\"\r\n />\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-multiply\"\r\n [(ngModel)]=\"filterMultiplyChecked\"\r\n (ngModelChange)=\"filterMultiplyCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-multiply\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n </div>\r\n <div class=\"filter-color-item\">\r\n <div\r\n [class]=\"\r\n 'tie-filter-blend-color tui-image-editor-button tui-image-editor-button-color-picker tui-image-editor-d-flex tui-image-editor-flex-column tui-image-editor-align-items-center ' +\r\n (filterBlendChecked ? 'active' : '')\r\n \"\r\n [title]=\"'tui-image-editor-angular-submenus-filter-blend' | translate\"\r\n >\r\n <input\r\n readonly\r\n class=\"tie-filter-blend-color-picker tui-image-editor-mb-2\"\r\n [(colorPicker)]=\"filterBlendColor\"\r\n [style.background]=\"filterBlendColor\"\r\n [cpOutputFormat]=\"'rgba'\"\r\n [cpPresetColors]=\"defaultFilterBlendColors\"\r\n (colorPickerChange)=\"filterBlendColorChanged($event)\"\r\n [cpUseRootViewContainer]=\"true\"\r\n />\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-blend\"\r\n [(ngModel)]=\"filterBlendChecked\"\r\n (ngModelChange)=\"filterBlendCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-blend\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.RangeValueAccessor, selector: "input[type=range][formControlName],input[type=range][formControl],input[type=range][ngModel]" }, { kind: "directive", type: i2.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ColorPickerDirective, selector: "[colorPicker]", inputs: ["colorPicker", "cpWidth", "cpHeight", "cpToggle", "cpDisabled", "cpIgnoredElements", "cpFallbackColor", "cpColorMode", "cpCmykEnabled", "cpOutputFormat", "cpAlphaChannel", "cpDisableInput", "cpDialogDisplay", "cpSaveClickOutside", "cpCloseClickOutside", "cpUseRootViewContainer", "cpPosition", "cpPositionOffset", "cpPositionRelativeToArrow", "cpOKButton", "cpOKButtonText", "cpOKButtonClass", "cpCancelButton", "cpCancelButtonText", "cpCancelButtonClass", "cpEyeDropper", "cpPresetLabel", "cpPresetColors", "cpPresetColorsClass", "cpMaxPresetColorsLength", "cpPresetEmptyMessage", "cpPresetEmptyMessageClass", "cpAddColorButton", "cpAddColorButtonText", "cpAddColorButtonClass", "cpRemoveColorButtonClass", "cpExtraTemplate"], outputs: ["cpInputChange", "cpToggleChange", "cpSliderChange", "cpSliderDragEnd", "cpSliderDragStart", "colorPickerOpen", "colorPickerClose", "colorPickerCancel", "colorPickerSelect", "colorPickerChange", "cpCmykColorChange", "cpPresetColorsChange"], exportAs: ["ngxColorPicker"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }] });
|
|
339
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: FilterComponent, decorators: [{
|
|
340
|
+
type: Component,
|
|
341
|
+
args: [{ selector: 'tui-image-editor-submenus-filter', template: "<div\r\n class=\"tui-image-editor-menu-filter tui-image-editor-d-flex tui-image-editor-justify-content-center\"\r\n>\r\n <div\r\n class=\"tui-image-editor-submenu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-overflowable-x tui-image-editor-py-3\"\r\n >\r\n <div class=\"tui-image-editor-submenu-align\">\r\n <div\r\n class=\"tui-image-editor-checkbox-wrap fixed-width tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-wrap tui-image-editor-justify-content-center\"\r\n >\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-grayscale\"\r\n [(ngModel)]=\"filterGrayscaleChecked\"\r\n (ngModelChange)=\"filterGrayscaleCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-grayscale\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-invert\"\r\n [(ngModel)]=\"filterInvertChecked\"\r\n (ngModelChange)=\"filterInvertCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-invert\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-sepia\"\r\n [(ngModel)]=\"filterSepiaChecked\"\r\n (ngModelChange)=\"filterSepiaCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-sepia\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-vintage\"\r\n [(ngModel)]=\"filterVintageChecked\"\r\n (ngModelChange)=\"filterVintageCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-sepia2\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-blur\"\r\n [(ngModel)]=\"filterBlurChecked\"\r\n (ngModelChange)=\"filterBlurCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-blur\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-sharpen\"\r\n [(ngModel)]=\"filterSharpenChecked\"\r\n (ngModelChange)=\"filterSharpenCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-sharpen\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-emboss\"\r\n [(ngModel)]=\"filterEmbossChecked\"\r\n (ngModelChange)=\"filterEmbossCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-emboss\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-partition\">\r\n <div></div>\r\n </div>\r\n <div class=\"tui-image-editor-submenu-align\">\r\n <div\r\n class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\"\r\n style=\"margin-bottom: 7px\"\r\n >\r\n <div class=\"tui-image-editor-checkbox-wrap\">\r\n <div class=\"tui-image-editor-checkbox\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-remove-white\"\r\n [(ngModel)]=\"filterWhiteRemovalChecked\"\r\n (ngModelChange)=\"filterWhiteRemovalCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-removeWhite\"\r\n | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n </div>\r\n <div\r\n class=\"tui-image-editor-newline tui-image-editor-range-wrap short tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap tui-image-editor-align-items-center\"\r\n >\r\n <label>{{\r\n \"tui-image-editor-angular-submenus-filter-removeWhite-distance\"\r\n | translate\r\n }}</label>\r\n <input\r\n type=\"range\"\r\n [(ngModel)]=\"filterWhiteRemovalDistance\"\r\n (ngModelChange)=\"filterWhiteRemovalDistanceChanged($event, true)\"\r\n (change)=\"filterWhiteRemovalDistanceChanged($event, false)\"\r\n min=\"0\"\r\n max=\"1\"\r\n step=\"0.001\"\r\n [disabled]=\"filterWhiteRemovalChecked == false\"\r\n />\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\">\r\n <div class=\"tui-image-editor-checkbox\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-brightness\"\r\n [(ngModel)]=\"filterBrightnessChecked\"\r\n (ngModelChange)=\"filterBrightnessCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-brightness\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-range-wrap short tui-image-editor-d-flex tui-image-editor-flex-row align-items-center tui-image-editor-my-2\">\r\n <input\r\n type=\"range\"\r\n [(ngModel)]=\"filterBrightnessValue\"\r\n (ngModelChange)=\"filterBrightnessValueChanged($event, true)\"\r\n (change)=\"filterBrightnessValueChanged($event, false)\"\r\n min=\"-1\"\r\n max=\"1\"\r\n step=\"0.03\"\r\n [disabled]=\"filterBrightnessChecked == false\"\r\n />\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\">\r\n <div class=\"tui-image-editor-checkbox\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-noise\"\r\n [(ngModel)]=\"filterNoiseChecked\"\r\n (ngModelChange)=\"filterNoiseCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-noise\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-range-wrap short tui-image-editor-d-flex tui-image-editor-flex-row align-items-center tui-image-editor-my-2\">\r\n <input\r\n type=\"range\"\r\n [(ngModel)]=\"filterNoiseValue\"\r\n (ngModelChange)=\"filterNoiseValueChanged($event, true)\"\r\n (change)=\"filterNoiseValueChanged($event, false)\"\r\n min=\"0\"\r\n max=\"1000\"\r\n step=\"10\"\r\n [disabled]=\"filterNoiseChecked == false\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-partition only-left-right\">\r\n <div></div>\r\n </div>\r\n <div class=\"tui-image-editor-submenu-align\">\r\n <div class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\">\r\n <div class=\"tui-image-editor-checkbox\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-pixelate\"\r\n [(ngModel)]=\"filterPixelateChecked\"\r\n (ngModelChange)=\"filterPixelateCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-pixelate\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n <div class=\"tui-image-editor-range-wrap short tui-image-editor-d-flex tui-image-editor-flex-row align-items-center tui-image-editor-my-2\">\r\n <input\r\n type=\"range\"\r\n [(ngModel)]=\"filterPixelateValue\"\r\n (ngModelChange)=\"filterPixelateValueChanged($event, true)\"\r\n (change)=\"filterPixelateValueChanged($event, false)\"\r\n min=\"2\"\r\n max=\"20\"\r\n step=\"1\"\r\n [disabled]=\"filterPixelateChecked == false\"\r\n />\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\">\r\n <div class=\"tui-image-editor-newline tui-image-editor-checkbox-wrap\">\r\n <div class=\"tui-image-editor-checkbox\">\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-color-filter\"\r\n [(ngModel)]=\"filterColorFilterChecked\"\r\n (ngModelChange)=\"filterColorFilterCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-colorFilter\"\r\n | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-newline tui-image-editor-range-wrap short\">\r\n <label>{{\r\n \"tui-image-editor-angular-submenus-filter-colorFilter-threshold\"\r\n | translate\r\n }}</label>\r\n <div class=\"tie-colorfilter-threshold-range tui-image-editor-range tui-image-editor-d-flex tui-image-editor-flex-row align-items-center tui-image-editor-my-2\">\r\n <input\r\n type=\"range\"\r\n [(ngModel)]=\"filterColorFilterThreshold\"\r\n (ngModelChange)=\"filterColorFilterThresholdChanged($event, true)\"\r\n (change)=\"filterColorFilterThresholdChanged($event, false)\"\r\n min=\"0\"\r\n max=\"1\"\r\n step=\"0.02\"\r\n [disabled]=\"filterColorFilterChecked == false\"\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"tui-image-editor-partition\">\r\n <div></div>\r\n </div>\r\n <div\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center\"\r\n >\r\n <div class=\"filter-color-item\">\r\n <div\r\n [class]=\"\r\n 'tie-filter-tint-color tui-image-editor-button tui-image-editor-button-color-picker tui-image-editor-d-flex tui-image-editor-flex-column tui-image-editor-align-items-center ' +\r\n (filterTintChecked ? 'active' : '')\r\n \"\r\n [title]=\"'tui-image-editor-angular-submenus-filter-tint' | translate\"\r\n >\r\n <input\r\n readonly\r\n class=\"tie-filter-tint-color-picker tui-image-editor-mb-2\"\r\n [(colorPicker)]=\"filterTintColor\"\r\n [style.background]=\"filterTintColor\"\r\n [cpOutputFormat]=\"'rgba'\"\r\n [cpPresetColors]=\"defaultFilterTintColors\"\r\n (colorPickerChange)=\"filterTintColorChanged($event)\"\r\n [cpUseRootViewContainer]=\"true\"\r\n />\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-tint\"\r\n [(ngModel)]=\"filterTintChecked\"\r\n (ngModelChange)=\"filterTintCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-tint\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n </div>\r\n <div class=\"filter-color-item\">\r\n <div\r\n [class]=\"\r\n 'tie-filter-multiply-color tui-image-editor-button tui-image-editor-button-color-picker tui-image-editor-d-flex tui-image-editor-flex-column tui-image-editor-align-items-center ' +\r\n (filterMultiplyChecked ? 'active' : '')\r\n \"\r\n [title]=\"\r\n 'tui-image-editor-angular-submenus-filter-multiply' | translate\r\n \"\r\n >\r\n <input\r\n readonly\r\n class=\"tie-filter-multiply-color-picker tui-image-editor-mb-2\"\r\n [(colorPicker)]=\"filterMultiplyColor\"\r\n [style.background]=\"filterMultiplyColor\"\r\n [cpOutputFormat]=\"'hex'\"\r\n [cpPresetColors]=\"defaultFilterMultiplyColors\"\r\n (colorPickerChange)=\"filterMultiplyColorChanged($event)\"\r\n [cpUseRootViewContainer]=\"true\"\r\n />\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-multiply\"\r\n [(ngModel)]=\"filterMultiplyChecked\"\r\n (ngModelChange)=\"filterMultiplyCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-multiply\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n </div>\r\n <div class=\"filter-color-item\">\r\n <div\r\n [class]=\"\r\n 'tie-filter-blend-color tui-image-editor-button tui-image-editor-button-color-picker tui-image-editor-d-flex tui-image-editor-flex-column tui-image-editor-align-items-center ' +\r\n (filterBlendChecked ? 'active' : '')\r\n \"\r\n [title]=\"'tui-image-editor-angular-submenus-filter-blend' | translate\"\r\n >\r\n <input\r\n readonly\r\n class=\"tie-filter-blend-color-picker tui-image-editor-mb-2\"\r\n [(colorPicker)]=\"filterBlendColor\"\r\n [style.background]=\"filterBlendColor\"\r\n [cpOutputFormat]=\"'rgba'\"\r\n [cpPresetColors]=\"defaultFilterBlendColors\"\r\n (colorPickerChange)=\"filterBlendColorChanged($event)\"\r\n [cpUseRootViewContainer]=\"true\"\r\n />\r\n <label\r\n class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n >\r\n <input\r\n type=\"checkbox\"\r\n class=\"tie-blend\"\r\n [(ngModel)]=\"filterBlendChecked\"\r\n (ngModelChange)=\"filterBlendCheckedChanged($event)\"\r\n />\r\n <span>{{\r\n \"tui-image-editor-angular-submenus-filter-blend\" | translate\r\n }}</span>\r\n </label>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n" }]
|
|
342
|
+
}], ctorParameters: function () { return [{ type: i1.HistoryService }]; }, propDecorators: { imageEditor: [{
|
|
343
|
+
type: Input
|
|
344
|
+
}] } });
|
|
345
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter.component.js","sourceRoot":"","sources":["../../../../../../projects/tui-image-editor-angular2/src/lib/submenus/filter/filter.component.ts","../../../../../../projects/tui-image-editor-angular2/src/lib/submenus/filter/filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\nimport { defaultColors, filterType, historyNames } from '../../consts';\r\nimport { HistoryItem, HistoryItemType } from '../../interfaces/history-item';\r\nimport { HistoryService } from '../../services/history.service';\r\nimport { removeFilter, rgbaToObject } from '../../utils';\r\n\r\n@Component({\r\n  selector: 'tui-image-editor-submenus-filter',\r\n  templateUrl: './filter.component.html',\r\n  styleUrls: ['./filter.component.css'],\r\n})\r\nexport class FilterComponent implements OnInit, OnDestroy {\r\n  @Input() imageEditor: any;\r\n  public activeObjectId: number;\r\n\r\n  public filterBlurChecked: boolean = false;\r\n  public filterBlurValue: number = 0.1;\r\n\r\n  public filterGrayscaleChecked: boolean = false;\r\n  public filterSepiaChecked: boolean = false;\r\n  public filterEmbossChecked: boolean = false;\r\n  public filterInvertChecked: boolean = false;\r\n  public filterVintageChecked: boolean = false;\r\n  public filterSharpenChecked: boolean = false;\r\n\r\n  public filterWhiteRemovalChecked: boolean = false;\r\n  public filterWhiteRemovalDistance: number = 0.5;\r\n\r\n  public filterBrightnessChecked: boolean = false;\r\n  public filterBrightnessValue: number = 0;\r\n\r\n  public filterNoiseChecked: boolean = false;\r\n  public filterNoiseValue: number = 100;\r\n\r\n  public filterPixelateChecked: boolean = false;\r\n  public filterPixelateValue: number = 15;\r\n\r\n  public filterColorFilterChecked: boolean = false;\r\n  public filterColorFilterThreshold: number = 0;\r\n\r\n  public defaultFilterTintColors: string[] = defaultColors;\r\n  public filterTintChecked: boolean = false;\r\n  public filterTintColor: string = 'rgba(3, 189, 158, 0.7)';\r\n\r\n  public defaultFilterMultiplyColors: string[] = defaultColors;\r\n  public filterMultiplyChecked: boolean = false;\r\n  public filterMultiplyColor: string = 'rgb(81, 92, 230)';\r\n\r\n  public defaultFilterBlendColors: string[] = defaultColors;\r\n  public filterBlendChecked: boolean = false;\r\n  public filterBlendColor: string = 'rgba(255, 187, 59, 1)';\r\n\r\n  private historyServiceSubscription: Subscription;\r\n\r\n  constructor(private historyService: HistoryService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.historyServiceSubscription = this.historyService.onChangeEmitter.subscribe(\r\n      (items) =>\r\n        items != null && items.length != 0\r\n          ? this.rebindFields(items)\r\n          : this.rebindFields(this.historyService.items)\r\n    );\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.historyServiceSubscription?.unsubscribe();\r\n  }\r\n\r\n  public rebindFields(items: HistoryItem[]) {\r\n    console.debug(items);\r\n    if (this.imageEditor != null) {\r\n      this.filterBlurChecked = this.imageEditor.hasFilter('blur');\r\n      this.filterBrightnessChecked = this.imageEditor.hasFilter('brightness');\r\n      if (this.filterBrightnessChecked) {\r\n        this.filterBrightnessValue = this.getAppliedFilterArgument(\r\n          items,\r\n          filterType.BRIGHTNESS,\r\n          0\r\n        );\r\n      }\r\n      this.filterColorFilterChecked =\r\n        this.imageEditor.hasFilter('removeColor') &&\r\n        this.hasAppliedFilter(items, filterType.REMOVE_COLOR);\r\n      if (this.filterColorFilterChecked) {\r\n        this.filterColorFilterThreshold = this.getAppliedFilterArgument(\r\n          items,\r\n          filterType.REMOVE_COLOR,\r\n          0\r\n        );\r\n      }\r\n      this.filterEmbossChecked = this.imageEditor.hasFilter('emboss');\r\n      this.filterGrayscaleChecked = this.imageEditor.hasFilter('grayscale');\r\n      this.filterInvertChecked = this.imageEditor.hasFilter('invert');\r\n      this.filterNoiseChecked = this.imageEditor.hasFilter('noise');\r\n      if (this.filterNoiseChecked) {\r\n        this.filterNoiseValue = this.getAppliedFilterArgument(\r\n          items,\r\n          filterType.NOISE,\r\n          0\r\n        );\r\n      }\r\n      this.filterPixelateChecked = this.imageEditor.hasFilter('pixelate');\r\n      if (this.filterPixelateChecked) {\r\n        this.filterPixelateValue = this.getAppliedFilterArgument(\r\n          items,\r\n          filterType.PIXELATE,\r\n          0\r\n        );\r\n      }\r\n      this.filterSepiaChecked = this.imageEditor.hasFilter('sepia');\r\n      this.filterSharpenChecked = this.imageEditor.hasFilter('sharpen');\r\n      this.filterVintageChecked = this.imageEditor.hasFilter('vintage');\r\n      this.filterWhiteRemovalChecked =\r\n        this.imageEditor.hasFilter('removeColor') &&\r\n        this.hasAppliedFilter(items, filterType.REMOVE_WHITE);\r\n      if (this.filterWhiteRemovalChecked) {\r\n        this.filterWhiteRemovalDistance = this.getAppliedFilterArgument(\r\n          items,\r\n          filterType.REMOVE_WHITE,\r\n          0\r\n        );\r\n      }\r\n\r\n      this.filterMultiplyChecked =\r\n        this.imageEditor.hasFilter('blendColor') &&\r\n        this.hasAppliedFilter(items, filterType.MULTIPLY);\r\n      if (this.filterMultiplyChecked) {\r\n        this.filterMultiplyColor = this.getAppliedFilterArgument(\r\n          items,\r\n          filterType.MULTIPLY,\r\n          0\r\n        );\r\n      }\r\n      this.filterTintChecked =\r\n        this.imageEditor.hasFilter('blendColor') &&\r\n        this.hasAppliedFilter(items, filterType.TINT);\r\n      if (this.filterTintChecked) {\r\n        this.filterTintColor = this.getAppliedFilterArgument(\r\n          items,\r\n          filterType.TINT,\r\n          0\r\n        );\r\n      }\r\n      this.filterBlendChecked =\r\n        this.imageEditor.hasFilter('blendColor') &&\r\n        this.hasAppliedFilter(items, filterType.BLEND);\r\n      if (this.filterBlendChecked) {\r\n        this.filterBlendColor = this.getAppliedFilterArgument(\r\n          items,\r\n          filterType.BLEND,\r\n          0\r\n        );\r\n      }\r\n    }\r\n  }\r\n\r\n  private getAppliedFilterArgument(\r\n    items: HistoryItem[],\r\n    type: filterType,\r\n    index: number\r\n  ): any {\r\n    let validItems = items.filter(\r\n      (f) => f.filterType === type && f.type === HistoryItemType.ApplyFilter\r\n    );\r\n    return validItems[validItems.length - 1].args[index];\r\n  }\r\n\r\n  private hasAppliedFilter(\r\n    historyItems: HistoryItem[],\r\n    type: filterType\r\n  ): boolean {\r\n    let hasFilter = false;\r\n    for (let i = 0; i < historyItems.length; i++) {\r\n      let item = historyItems[i];\r\n      if (\r\n        item.type === HistoryItemType.ApplyFilter &&\r\n        item.filterType === type\r\n      ) {\r\n        hasFilter = true;\r\n      } else if (\r\n        hasFilter == true &&\r\n        [filterType.TINT, filterType.BLEND, filterType.MULTIPLY].some(\r\n          (t) => t === type\r\n        ) &&\r\n        item.type === HistoryItemType.RemoveFilter &&\r\n        item.filterType === filterType.BLEND_OR_TINT_OR_MULTIPLY\r\n      ) {\r\n        hasFilter = false;\r\n      } else if (\r\n        hasFilter == true &&\r\n        [filterType.REMOVE_COLOR, filterType.REMOVE_WHITE].some(\r\n          (t) => t === type\r\n        ) &&\r\n        item.type === HistoryItemType.RemoveFilter &&\r\n        item.filterType === filterType.REMOVE_COLOR_OR_WHITE\r\n      ) {\r\n        hasFilter = false;\r\n      }\r\n    }\r\n    return hasFilter;\r\n  }\r\n\r\n  filterWhiteRemovalCheckedChanged(newValue: boolean) {\r\n    this.filterApply('white-removal');\r\n  }\r\n\r\n  filterWhiteRemovalDistanceChanged(newValue: number, isSilent: boolean) {\r\n    this.filterApply('white-removal', isSilent);\r\n  }\r\n\r\n  filterBrightnessCheckedChanged(newValue: boolean) {\r\n    this.filterApply('brightness');\r\n  }\r\n\r\n  filterBrightnessValueChanged(newValue: number, isSilent: boolean) {\r\n    this.filterApply('brightness', isSilent);\r\n  }\r\n\r\n  filterNoiseCheckedChanged(newValue: boolean) {\r\n    this.filterApply('noise');\r\n  }\r\n\r\n  filterNoiseValueChanged(newValue: number, isSilent: boolean) {\r\n    this.filterApply('noise', isSilent);\r\n  }\r\n\r\n  filterPixelateCheckedChanged(newValue: boolean) {\r\n    this.filterApply('pixelate');\r\n  }\r\n\r\n  filterPixelateValueChanged(newValue: number, isSilent: boolean) {\r\n    this.filterApply('pixelate', isSilent);\r\n  }\r\n\r\n  filterColorFilterCheckedChanged(newValue: boolean) {\r\n    this.filterApply('removeColor');\r\n  }\r\n\r\n  filterColorFilterThresholdChanged(newValue: number, isSilent: boolean) {\r\n    this.filterApply('removeColor', isSilent);\r\n  }\r\n\r\n  filterTintColorChanged(newColor: string) {\r\n    this.filterApply('tint');\r\n  }\r\n\r\n  filterTintCheckedChanged(newValue: boolean) {\r\n    this.filterApply('tint');\r\n    if (this.filterTintChecked) {\r\n      this.filterMultiplyChecked = false;\r\n      this.filterBlendChecked = false;\r\n    }\r\n  }\r\n\r\n  filterMultiplyColorChanged(newColor: string) {\r\n    this.filterApply('multiply');\r\n  }\r\n\r\n  filterMultiplyCheckedChanged(newValue: boolean) {\r\n    this.filterApply('multiply');\r\n    if (this.filterMultiplyChecked) {\r\n      this.filterTintChecked = false;\r\n      this.filterBlendChecked = false;\r\n    }\r\n  }\r\n\r\n  filterBlendColorChanged(newColor: string) {\r\n    this.filterApply('blend');\r\n  }\r\n\r\n  filterBlendCheckedChanged(newValue: boolean) {\r\n    this.filterApply('blend');\r\n    if (this.filterBlendChecked) {\r\n      this.filterMultiplyChecked = false;\r\n      this.filterTintChecked = false;\r\n    }\r\n  }\r\n\r\n  filterBlurCheckedChanged(newValue: boolean) {\r\n    this.filterApply('blur');\r\n  }\r\n\r\n  filterGrayscaleCheckedChanged(newValue: boolean) {\r\n    this.filterApply('grayscale');\r\n  }\r\n\r\n  filterSepiaCheckedChanged(newValue: boolean) {\r\n    this.filterApply('sepia');\r\n  }\r\n\r\n  filterEmbossCheckedChanged(newValue: boolean) {\r\n    this.filterApply('emboss');\r\n  }\r\n\r\n  filterInvertCheckedChanged(newValue: boolean) {\r\n    this.filterApply('invert');\r\n  }\r\n\r\n  filterVintageCheckedChanged(newValue: boolean) {\r\n    this.filterApply('vintage');\r\n  }\r\n\r\n  filterSharpenCheckedChanged(newValue: boolean) {\r\n    this.filterApply('sharpen');\r\n  }\r\n\r\n  filterApply(\r\n    type:\r\n      | 'white-removal'\r\n      | 'brightness'\r\n      | 'noise'\r\n      | 'pixelate'\r\n      | 'removeColor'\r\n      | 'blur'\r\n      | 'blend'\r\n      | 'multiply'\r\n      | 'tint'\r\n      | 'grayscale'\r\n      | 'sepia'\r\n      | 'emboss'\r\n      | 'invert'\r\n      | 'vintage'\r\n      | 'sharpen',\r\n    isSilent: boolean = false\r\n  ) {\r\n    switch (type) {\r\n      case 'white-removal':\r\n        this.filterApplyConfirmed(\r\n          this.filterWhiteRemovalChecked,\r\n          'removeColor',\r\n          {\r\n            color: '#FFFFFF',\r\n            useAlpha: false,\r\n            distance: this.filterWhiteRemovalDistance,\r\n          },\r\n          isSilent\r\n        );\r\n        break;\r\n      case 'brightness':\r\n        this.filterApplyConfirmed(\r\n          this.filterBrightnessChecked,\r\n          'brightness',\r\n          {\r\n            brightness: this.filterBrightnessValue,\r\n          },\r\n          isSilent\r\n        );\r\n        break;\r\n      case 'noise':\r\n        this.filterApplyConfirmed(\r\n          this.filterNoiseChecked,\r\n          'noise',\r\n          {\r\n            noise: this.filterNoiseValue,\r\n          },\r\n          isSilent\r\n        );\r\n        break;\r\n      case 'pixelate':\r\n        this.filterApplyConfirmed(\r\n          this.filterPixelateChecked,\r\n          'pixelate',\r\n          {\r\n            blocksize: this.filterPixelateValue,\r\n          },\r\n          isSilent\r\n        );\r\n        break;\r\n      case 'removeColor':\r\n        this.filterApplyConfirmed(\r\n          this.filterColorFilterChecked,\r\n          'removeColor',\r\n          {\r\n            color: '#FFFFFF',\r\n            distance: this.filterColorFilterThreshold,\r\n          },\r\n          isSilent\r\n        );\r\n        break;\r\n      case 'blur':\r\n        this.filterApplyConfirmed(\r\n          this.filterBlurChecked,\r\n          'blur',\r\n          {\r\n            blur: this.filterBlurValue,\r\n          },\r\n          isSilent\r\n        );\r\n        break;\r\n      case 'blend':\r\n        this.filterApplyConfirmed(\r\n          this.filterBlendChecked,\r\n          'blendColor',\r\n          {\r\n            mode: 'add',\r\n            color: this.filterBlendColor,\r\n          },\r\n          isSilent\r\n        );\r\n        break;\r\n      case 'multiply':\r\n        this.filterApplyConfirmed(\r\n          this.filterMultiplyChecked,\r\n          'blendColor',\r\n          {\r\n            mode: 'multiply',\r\n            color: this.filterMultiplyColor,\r\n          },\r\n          isSilent\r\n        );\r\n        break;\r\n      case 'tint':\r\n        let rgbTint = rgbaToObject(this.filterTintColor);\r\n\r\n        this.filterApplyConfirmed(\r\n          this.filterTintChecked,\r\n          'blendColor',\r\n          {\r\n            mode: 'tint',\r\n            color: rgbTint.hexString,\r\n            alpha: rgbTint.alpha,\r\n          },\r\n          isSilent\r\n        );\r\n        break;\r\n      case 'grayscale':\r\n        this.filterApplyConfirmed(\r\n          this.filterGrayscaleChecked,\r\n          type,\r\n          {},\r\n          isSilent\r\n        );\r\n        break;\r\n      case 'sepia':\r\n        this.filterApplyConfirmed(this.filterSepiaChecked, type, {}, isSilent);\r\n        break;\r\n      case 'emboss':\r\n        this.filterApplyConfirmed(this.filterEmbossChecked, type, {}, isSilent);\r\n        break;\r\n      case 'invert':\r\n        this.filterApplyConfirmed(this.filterInvertChecked, type, {}, isSilent);\r\n        break;\r\n      case 'vintage':\r\n        this.filterApplyConfirmed(\r\n          this.filterVintageChecked,\r\n          type,\r\n          {},\r\n          isSilent\r\n        );\r\n        break;\r\n      case 'sharpen':\r\n        this.filterApplyConfirmed(\r\n          this.filterSharpenChecked,\r\n          type,\r\n          {},\r\n          isSilent\r\n        );\r\n        break;\r\n    }\r\n  }\r\n\r\n  async filterApplyConfirmed(\r\n    applying: boolean,\r\n    type:\r\n      | 'removeColor'\r\n      | 'brightness'\r\n      | 'noise'\r\n      | 'pixelate'\r\n      | 'blur'\r\n      | 'blendColor'\r\n      | 'grayscale'\r\n      | 'sepia'\r\n      | 'emboss'\r\n      | 'invert'\r\n      | 'vintage'\r\n      | 'sharpen',\r\n    options: any,\r\n    isSilent: boolean = false\r\n  ) {\r\n    let functionToExecute = async () => {\r\n      if (applying) {\r\n        if (type === 'blendColor' && this.imageEditor.hasFilter('blendColor')) {\r\n          switch (options.mode) {\r\n            case 'add':\r\n              this.filterTintChecked = false;\r\n              this.filterMultiplyChecked = false;\r\n              break;\r\n            case 'multiply':\r\n              this.filterTintChecked = false;\r\n              this.filterBlendChecked = false;\r\n              break;\r\n            case 'tint':\r\n              this.filterBlendChecked = false;\r\n              this.filterMultiplyChecked = false;\r\n              break;\r\n          }\r\n          await removeFilter(this.imageEditor, type, isSilent);\r\n        } else if (\r\n          type === 'removeColor' &&\r\n          this.imageEditor.hasFilter('removeColor')\r\n        ) {\r\n          if (options.useAlpha != null) {\r\n            this.filterColorFilterChecked = false;\r\n          } else {\r\n            this.filterWhiteRemovalChecked = false;\r\n          }\r\n          await removeFilter(this.imageEditor, type, isSilent);\r\n        }\r\n        await this.imageEditor.applyFilter(type, options, isSilent);\r\n      } else if (this.imageEditor.hasFilter(type)) {\r\n        await removeFilter(this.imageEditor, type, isSilent);\r\n        if (type == 'blendColor') {\r\n          this.filterTintChecked = false;\r\n          this.filterMultiplyChecked = false;\r\n          this.filterBlendChecked = false;\r\n        }\r\n      }\r\n    };\r\n    if (isSilent) {\r\n      await functionToExecute();\r\n    } else {\r\n      setTimeout(async () => {\r\n        await functionToExecute();\r\n      });\r\n    }\r\n  }\r\n}\r\n","<div\r\n  class=\"tui-image-editor-menu-filter tui-image-editor-d-flex tui-image-editor-justify-content-center\"\r\n>\r\n  <div\r\n    class=\"tui-image-editor-submenu-item tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-overflowable-x tui-image-editor-py-3\"\r\n  >\r\n    <div class=\"tui-image-editor-submenu-align\">\r\n      <div\r\n        class=\"tui-image-editor-checkbox-wrap fixed-width tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-wrap tui-image-editor-justify-content-center\"\r\n      >\r\n        <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-grayscale\"\r\n              [(ngModel)]=\"filterGrayscaleChecked\"\r\n              (ngModelChange)=\"filterGrayscaleCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-grayscale\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n        <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-invert\"\r\n              [(ngModel)]=\"filterInvertChecked\"\r\n              (ngModelChange)=\"filterInvertCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-invert\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n        <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-sepia\"\r\n              [(ngModel)]=\"filterSepiaChecked\"\r\n              (ngModelChange)=\"filterSepiaCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-sepia\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n        <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-vintage\"\r\n              [(ngModel)]=\"filterVintageChecked\"\r\n              (ngModelChange)=\"filterVintageCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-sepia2\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n        <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-blur\"\r\n              [(ngModel)]=\"filterBlurChecked\"\r\n              (ngModelChange)=\"filterBlurCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-blur\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n        <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-sharpen\"\r\n              [(ngModel)]=\"filterSharpenChecked\"\r\n              (ngModelChange)=\"filterSharpenCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-sharpen\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n        <div class=\"tui-image-editor-checkbox tui-image-editor-align-self-center\">\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-emboss\"\r\n              [(ngModel)]=\"filterEmbossChecked\"\r\n              (ngModelChange)=\"filterEmbossCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-emboss\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"tui-image-editor-partition\">\r\n      <div></div>\r\n    </div>\r\n    <div class=\"tui-image-editor-submenu-align\">\r\n      <div\r\n        class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\"\r\n        style=\"margin-bottom: 7px\"\r\n      >\r\n        <div class=\"tui-image-editor-checkbox-wrap\">\r\n          <div class=\"tui-image-editor-checkbox\">\r\n            <label\r\n              class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n            >\r\n              <input\r\n                type=\"checkbox\"\r\n                class=\"tie-remove-white\"\r\n                [(ngModel)]=\"filterWhiteRemovalChecked\"\r\n                (ngModelChange)=\"filterWhiteRemovalCheckedChanged($event)\"\r\n              />\r\n              <span>{{\r\n                \"tui-image-editor-angular-submenus-filter-removeWhite\"\r\n                  | translate\r\n              }}</span>\r\n            </label>\r\n          </div>\r\n        </div>\r\n        <div\r\n          class=\"tui-image-editor-newline tui-image-editor-range-wrap short tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-flex-nowrap tui-image-editor-align-items-center\"\r\n        >\r\n          <label>{{\r\n            \"tui-image-editor-angular-submenus-filter-removeWhite-distance\"\r\n              | translate\r\n          }}</label>\r\n          <input\r\n            type=\"range\"\r\n            [(ngModel)]=\"filterWhiteRemovalDistance\"\r\n            (ngModelChange)=\"filterWhiteRemovalDistanceChanged($event, true)\"\r\n            (change)=\"filterWhiteRemovalDistanceChanged($event, false)\"\r\n            min=\"0\"\r\n            max=\"1\"\r\n            step=\"0.001\"\r\n            [disabled]=\"filterWhiteRemovalChecked == false\"\r\n          />\r\n        </div>\r\n      </div>\r\n      <div class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\">\r\n        <div class=\"tui-image-editor-checkbox\">\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-brightness\"\r\n              [(ngModel)]=\"filterBrightnessChecked\"\r\n              (ngModelChange)=\"filterBrightnessCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-brightness\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n        <div class=\"tui-image-editor-range-wrap short tui-image-editor-d-flex tui-image-editor-flex-row align-items-center tui-image-editor-my-2\">\r\n          <input\r\n            type=\"range\"\r\n            [(ngModel)]=\"filterBrightnessValue\"\r\n            (ngModelChange)=\"filterBrightnessValueChanged($event, true)\"\r\n            (change)=\"filterBrightnessValueChanged($event, false)\"\r\n            min=\"-1\"\r\n            max=\"1\"\r\n            step=\"0.03\"\r\n            [disabled]=\"filterBrightnessChecked == false\"\r\n          />\r\n        </div>\r\n      </div>\r\n      <div class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\">\r\n        <div class=\"tui-image-editor-checkbox\">\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-noise\"\r\n              [(ngModel)]=\"filterNoiseChecked\"\r\n              (ngModelChange)=\"filterNoiseCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-noise\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n        <div class=\"tui-image-editor-range-wrap short tui-image-editor-d-flex tui-image-editor-flex-row align-items-center tui-image-editor-my-2\">\r\n          <input\r\n            type=\"range\"\r\n            [(ngModel)]=\"filterNoiseValue\"\r\n            (ngModelChange)=\"filterNoiseValueChanged($event, true)\"\r\n            (change)=\"filterNoiseValueChanged($event, false)\"\r\n            min=\"0\"\r\n            max=\"1000\"\r\n            step=\"10\"\r\n            [disabled]=\"filterNoiseChecked == false\"\r\n          />\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"tui-image-editor-partition only-left-right\">\r\n      <div></div>\r\n    </div>\r\n    <div class=\"tui-image-editor-submenu-align\">\r\n      <div class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\">\r\n        <div class=\"tui-image-editor-checkbox\">\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-pixelate\"\r\n              [(ngModel)]=\"filterPixelateChecked\"\r\n              (ngModelChange)=\"filterPixelateCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-pixelate\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n        <div class=\"tui-image-editor-range-wrap short tui-image-editor-d-flex tui-image-editor-flex-row align-items-center tui-image-editor-my-2\">\r\n          <input\r\n            type=\"range\"\r\n            [(ngModel)]=\"filterPixelateValue\"\r\n            (ngModelChange)=\"filterPixelateValueChanged($event, true)\"\r\n            (change)=\"filterPixelateValueChanged($event, false)\"\r\n            min=\"2\"\r\n            max=\"20\"\r\n            step=\"1\"\r\n            [disabled]=\"filterPixelateChecked == false\"\r\n          />\r\n        </div>\r\n      </div>\r\n      <div class=\"tui-image-editor-checkbox-group tui-image-editor-disabled\">\r\n        <div class=\"tui-image-editor-newline tui-image-editor-checkbox-wrap\">\r\n          <div class=\"tui-image-editor-checkbox\">\r\n            <label\r\n              class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n            >\r\n              <input\r\n                type=\"checkbox\"\r\n                class=\"tie-color-filter\"\r\n                [(ngModel)]=\"filterColorFilterChecked\"\r\n                (ngModelChange)=\"filterColorFilterCheckedChanged($event)\"\r\n              />\r\n              <span>{{\r\n                \"tui-image-editor-angular-submenus-filter-colorFilter\"\r\n                  | translate\r\n              }}</span>\r\n            </label>\r\n          </div>\r\n        </div>\r\n        <div class=\"tui-image-editor-newline tui-image-editor-range-wrap short\">\r\n          <label>{{\r\n            \"tui-image-editor-angular-submenus-filter-colorFilter-threshold\"\r\n              | translate\r\n          }}</label>\r\n          <div class=\"tie-colorfilter-threshold-range tui-image-editor-range tui-image-editor-d-flex tui-image-editor-flex-row align-items-center tui-image-editor-my-2\">\r\n            <input\r\n              type=\"range\"\r\n              [(ngModel)]=\"filterColorFilterThreshold\"\r\n              (ngModelChange)=\"filterColorFilterThresholdChanged($event, true)\"\r\n              (change)=\"filterColorFilterThresholdChanged($event, false)\"\r\n              min=\"0\"\r\n              max=\"1\"\r\n              step=\"0.02\"\r\n              [disabled]=\"filterColorFilterChecked == false\"\r\n            />\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"tui-image-editor-partition\">\r\n      <div></div>\r\n    </div>\r\n    <div\r\n      class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center\"\r\n    >\r\n      <div class=\"filter-color-item\">\r\n        <div\r\n          [class]=\"\r\n            'tie-filter-tint-color tui-image-editor-button tui-image-editor-button-color-picker tui-image-editor-d-flex tui-image-editor-flex-column tui-image-editor-align-items-center ' +\r\n            (filterTintChecked ? 'active' : '')\r\n          \"\r\n          [title]=\"'tui-image-editor-angular-submenus-filter-tint' | translate\"\r\n        >\r\n          <input\r\n            readonly\r\n            class=\"tie-filter-tint-color-picker tui-image-editor-mb-2\"\r\n            [(colorPicker)]=\"filterTintColor\"\r\n            [style.background]=\"filterTintColor\"\r\n            [cpOutputFormat]=\"'rgba'\"\r\n            [cpPresetColors]=\"defaultFilterTintColors\"\r\n            (colorPickerChange)=\"filterTintColorChanged($event)\"\r\n            [cpUseRootViewContainer]=\"true\"\r\n          />\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-tint\"\r\n              [(ngModel)]=\"filterTintChecked\"\r\n              (ngModelChange)=\"filterTintCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-tint\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n      </div>\r\n      <div class=\"filter-color-item\">\r\n        <div\r\n          [class]=\"\r\n            'tie-filter-multiply-color tui-image-editor-button tui-image-editor-button-color-picker tui-image-editor-d-flex tui-image-editor-flex-column tui-image-editor-align-items-center ' +\r\n            (filterMultiplyChecked ? 'active' : '')\r\n          \"\r\n          [title]=\"\r\n            'tui-image-editor-angular-submenus-filter-multiply' | translate\r\n          \"\r\n        >\r\n          <input\r\n            readonly\r\n            class=\"tie-filter-multiply-color-picker tui-image-editor-mb-2\"\r\n            [(colorPicker)]=\"filterMultiplyColor\"\r\n            [style.background]=\"filterMultiplyColor\"\r\n            [cpOutputFormat]=\"'hex'\"\r\n            [cpPresetColors]=\"defaultFilterMultiplyColors\"\r\n            (colorPickerChange)=\"filterMultiplyColorChanged($event)\"\r\n            [cpUseRootViewContainer]=\"true\"\r\n          />\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-multiply\"\r\n              [(ngModel)]=\"filterMultiplyChecked\"\r\n              (ngModelChange)=\"filterMultiplyCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-multiply\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n      </div>\r\n      <div class=\"filter-color-item\">\r\n        <div\r\n          [class]=\"\r\n            'tie-filter-blend-color tui-image-editor-button tui-image-editor-button-color-picker tui-image-editor-d-flex tui-image-editor-flex-column tui-image-editor-align-items-center ' +\r\n            (filterBlendChecked ? 'active' : '')\r\n          \"\r\n          [title]=\"'tui-image-editor-angular-submenus-filter-blend' | translate\"\r\n        >\r\n          <input\r\n            readonly\r\n            class=\"tie-filter-blend-color-picker tui-image-editor-mb-2\"\r\n            [(colorPicker)]=\"filterBlendColor\"\r\n            [style.background]=\"filterBlendColor\"\r\n            [cpOutputFormat]=\"'rgba'\"\r\n            [cpPresetColors]=\"defaultFilterBlendColors\"\r\n            (colorPickerChange)=\"filterBlendColorChanged($event)\"\r\n            [cpUseRootViewContainer]=\"true\"\r\n          />\r\n          <label\r\n            class=\"tui-image-editor-d-flex tui-image-editor-flex-row tui-image-editor-align-items-center tui-image-editor-flex-nowrap\"\r\n          >\r\n            <input\r\n              type=\"checkbox\"\r\n              class=\"tie-blend\"\r\n              [(ngModel)]=\"filterBlendChecked\"\r\n              (ngModelChange)=\"filterBlendCheckedChanged($event)\"\r\n            />\r\n            <span>{{\r\n              \"tui-image-editor-angular-submenus-filter-blend\" | translate\r\n            }}</span>\r\n          </label>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|