@taiga-ui/legacy 4.0.0-rc.8 → 4.0.0
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/components/color-selector/color-selector.component.d.ts +4 -10
- package/components/color-selector/color-selector.options.d.ts +47 -0
- package/components/color-selector/index.d.ts +1 -0
- package/components/input-time/input-time.component.d.ts +5 -1
- package/esm2022/components/color-selector/color-selector.component.mjs +31 -89
- package/esm2022/components/color-selector/color-selector.options.mjs +94 -0
- package/esm2022/components/color-selector/index.mjs +2 -1
- package/esm2022/components/input-number/input-number.component.mjs +2 -2
- package/esm2022/components/input-password/input-password.component.mjs +3 -3
- package/esm2022/components/input-tag/input-tag.component.mjs +3 -3
- package/esm2022/components/input-time/input-time.component.mjs +10 -2
- package/esm2022/components/svg/svg.component.mjs +2 -2
- package/esm2022/index.mjs +2 -1
- package/esm2022/services/index.mjs +2 -0
- package/esm2022/services/static-request.service.mjs +36 -0
- package/esm2022/services/taiga-ui-legacy-services.mjs +5 -0
- package/fesm2022/taiga-ui-legacy-components-color-selector.mjs +123 -90
- package/fesm2022/taiga-ui-legacy-components-color-selector.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-number.mjs +2 -2
- package/fesm2022/taiga-ui-legacy-components-input-number.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-password.mjs +2 -2
- package/fesm2022/taiga-ui-legacy-components-input-password.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-tag.mjs +2 -2
- package/fesm2022/taiga-ui-legacy-components-input-tag.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-input-time.mjs +9 -1
- package/fesm2022/taiga-ui-legacy-components-input-time.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-components-svg.mjs +1 -1
- package/fesm2022/taiga-ui-legacy-components-svg.mjs.map +1 -1
- package/fesm2022/taiga-ui-legacy-services.mjs +42 -0
- package/fesm2022/taiga-ui-legacy-services.mjs.map +1 -0
- package/fesm2022/taiga-ui-legacy.mjs +1 -0
- package/fesm2022/taiga-ui-legacy.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/package.json +7 -1
- package/services/index.d.ts +1 -0
- package/services/static-request.service.d.ts +11 -0
- package/styles/mixins/mixins.less +2 -2
- package/utils/icons-path-factory.d.ts +1 -1
|
@@ -1,23 +1,17 @@
|
|
|
1
|
-
import { EventEmitter
|
|
1
|
+
import { EventEmitter } from '@angular/core';
|
|
2
2
|
import type { SafeStyle } from '@angular/platform-browser';
|
|
3
3
|
import type { TuiGradientDirection } from '@taiga-ui/cdk/utils/color';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
/**
|
|
6
|
-
* @deprecated: drop in v5.0
|
|
7
|
-
*/
|
|
8
|
-
export declare const TUI_COLOR_SELECTOR_MODE_NAMES: InjectionToken<[string, string]>;
|
|
9
|
-
/**
|
|
10
|
-
* @deprecated: drop in v5.0
|
|
11
|
-
*/
|
|
12
|
-
export declare const TUI_DEFAULT_INPUT_COLORS: Map<string, string>;
|
|
13
5
|
/**
|
|
14
6
|
* @deprecated: drop in v5.0
|
|
15
7
|
*/
|
|
16
8
|
export declare class TuiColorSelectorComponent {
|
|
9
|
+
private readonly selectorOptions;
|
|
17
10
|
private stops;
|
|
18
11
|
private currentStop;
|
|
19
12
|
private direction;
|
|
20
13
|
private readonly sanitizer;
|
|
14
|
+
protected open: boolean;
|
|
21
15
|
colors: ReadonlyMap<string, string>;
|
|
22
16
|
readonly colorChange: EventEmitter<string>;
|
|
23
17
|
color: [number, number, number, number];
|
|
@@ -25,6 +19,7 @@ export declare class TuiColorSelectorComponent {
|
|
|
25
19
|
currentMode: string;
|
|
26
20
|
readonly buttons: readonly TuiGradientDirection[];
|
|
27
21
|
set colorSetter(color: string);
|
|
22
|
+
get selectorMode(): boolean;
|
|
28
23
|
get palette(): Map<string, string>;
|
|
29
24
|
get stopsKeys(): number[];
|
|
30
25
|
get currentColor(): [number, number, number, number];
|
|
@@ -47,7 +42,6 @@ export declare class TuiColorSelectorComponent {
|
|
|
47
42
|
private addStop;
|
|
48
43
|
private removeStop;
|
|
49
44
|
private replaceStop;
|
|
50
|
-
private parse;
|
|
51
45
|
private parseGradient;
|
|
52
46
|
private parseColor;
|
|
53
47
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiColorSelectorComponent, never>;
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import type { Provider } from '@angular/core';
|
|
2
|
+
import { InjectionToken } from '@angular/core';
|
|
3
|
+
import type { TuiGradientDirection } from '@taiga-ui/cdk/utils/color';
|
|
4
|
+
/**
|
|
5
|
+
* @deprecated: drop in v5.0
|
|
6
|
+
*/
|
|
7
|
+
export declare const TUI_COLOR_SELECTOR_MODE_NAMES: InjectionToken<[string, string]>;
|
|
8
|
+
/**
|
|
9
|
+
* @deprecated: drop in v5.0
|
|
10
|
+
*/
|
|
11
|
+
export declare const TUI_DEFAULT_INPUT_COLORS: Map<string, string>;
|
|
12
|
+
/**
|
|
13
|
+
* @deprecated: drop in v5.0
|
|
14
|
+
*/
|
|
15
|
+
export declare const TuiColorSelectorMode: {
|
|
16
|
+
readonly SolidColor: 0;
|
|
17
|
+
readonly Gradient: 1;
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* @deprecated: drop in v5.0
|
|
21
|
+
*/
|
|
22
|
+
export interface TuiColorSelectorOptions {
|
|
23
|
+
readonly mode: (typeof TuiColorSelectorMode)[keyof typeof TuiColorSelectorMode];
|
|
24
|
+
readonly selectorMode: boolean;
|
|
25
|
+
readonly color: [number, number, number, number];
|
|
26
|
+
readonly colors: ReadonlyMap<string, string>;
|
|
27
|
+
readonly gradient: {
|
|
28
|
+
readonly icons: Record<TuiGradientDirection, string>;
|
|
29
|
+
readonly steps: ReadonlyArray<[number, [number, number, number, number]]>;
|
|
30
|
+
readonly stop: number;
|
|
31
|
+
readonly direction: TuiGradientDirection;
|
|
32
|
+
readonly emptyStop: [number, number, number, number];
|
|
33
|
+
readonly buttons: readonly TuiGradientDirection[];
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* @deprecated: drop in v5.0
|
|
38
|
+
*/
|
|
39
|
+
export declare const TUI_COLOR_SELECTOR_DEFAULT_OPTIONS: TuiColorSelectorOptions;
|
|
40
|
+
/**
|
|
41
|
+
* @deprecated: drop in v5.0
|
|
42
|
+
*/
|
|
43
|
+
export declare const TUI_COLOR_SELECTOR_OPTIONS: InjectionToken<TuiColorSelectorOptions>;
|
|
44
|
+
/**
|
|
45
|
+
* @deprecated: drop in v5.0
|
|
46
|
+
*/
|
|
47
|
+
export declare function tuiColorSelectorOptionsProvider(options: Partial<TuiColorSelectorOptions>): Provider;
|
|
@@ -4,6 +4,7 @@ export * from './color-picker/color-picker.component';
|
|
|
4
4
|
export * from './color-picker/color-picker.module';
|
|
5
5
|
export * from './color-selector.component';
|
|
6
6
|
export * from './color-selector.module';
|
|
7
|
+
export * from './color-selector.options';
|
|
7
8
|
export * from './flat-picker/flat-picker.component';
|
|
8
9
|
export * from './flat-picker/flat-picker.module';
|
|
9
10
|
export * from './linear-multi-picker/linear-multi-picker.component';
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import type { MaskitoOptions } from '@maskito/core';
|
|
2
|
+
import type { TuiValueTransformer } from '@taiga-ui/cdk/classes';
|
|
2
3
|
import type { TuiTimeMode } from '@taiga-ui/cdk/date-time';
|
|
3
4
|
import { TuiTime } from '@taiga-ui/cdk/date-time';
|
|
4
|
-
import type { TuiBooleanHandler } from '@taiga-ui/cdk/types';
|
|
5
|
+
import type { TuiBooleanHandler, TuiIdentityMatcher } from '@taiga-ui/cdk/types';
|
|
5
6
|
import type { TuiDataListHost } from '@taiga-ui/core/components/data-list';
|
|
6
7
|
import type { TuiSizeL, TuiSizeS } from '@taiga-ui/core/types';
|
|
7
8
|
import { AbstractTuiNullableControl } from '@taiga-ui/legacy/classes';
|
|
@@ -19,6 +20,7 @@ export declare class TuiInputTimeComponent extends AbstractTuiNullableControl<Tu
|
|
|
19
20
|
private readonly isMobile;
|
|
20
21
|
private readonly isIOS;
|
|
21
22
|
private readonly textfieldSize;
|
|
23
|
+
protected readonly valueTransformer: TuiValueTransformer<TuiTime | null> | null;
|
|
22
24
|
protected open: boolean;
|
|
23
25
|
disabledItemHandler: TuiBooleanHandler<TuiTime>;
|
|
24
26
|
items: readonly TuiTime[];
|
|
@@ -31,6 +33,8 @@ export declare class TuiInputTimeComponent extends AbstractTuiNullableControl<Tu
|
|
|
31
33
|
get computedValue(): string;
|
|
32
34
|
get nativeValue(): string;
|
|
33
35
|
set nativeValue(value: string);
|
|
36
|
+
readonly identityMatcher: TuiIdentityMatcher<TuiTime>;
|
|
37
|
+
checkOption(option: TuiTime): void;
|
|
34
38
|
handleOption(item: TuiTime): void;
|
|
35
39
|
writeValue(value: TuiTime | null): void;
|
|
36
40
|
onValueChange(value: string): void;
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, inject,
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output, } from '@angular/core';
|
|
3
3
|
import { DomSanitizer } from '@angular/platform-browser';
|
|
4
4
|
import { tuiGetGradientData, tuiParseColor, tuiParseGradient, } from '@taiga-ui/cdk/utils/color';
|
|
5
5
|
import { tuiDefaultSort, tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
6
|
+
import { TUI_COLOR_SELECTOR_MODE_NAMES, TUI_COLOR_SELECTOR_OPTIONS, TuiColorSelectorMode, } from './color-selector.options';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@angular/common";
|
|
8
9
|
import * as i2 from "@taiga-ui/core/components/button";
|
|
@@ -16,84 +17,34 @@ import * as i9 from "./palette/palette.component";
|
|
|
16
17
|
import * as i10 from "@taiga-ui/core/directives/hint";
|
|
17
18
|
import * as i11 from "@taiga-ui/kit/directives/chevron";
|
|
18
19
|
import * as i12 from "@taiga-ui/core/components/icon";
|
|
19
|
-
/**
|
|
20
|
-
* @deprecated: drop in v5.0
|
|
21
|
-
*/
|
|
22
|
-
export const TUI_COLOR_SELECTOR_MODE_NAMES = new InjectionToken('[TUI_COLOR_SELECTOR_MODE_NAMES]', {
|
|
23
|
-
factory: () => ['Solid color', 'Gradient'],
|
|
24
|
-
});
|
|
25
|
-
/**
|
|
26
|
-
* @deprecated: drop in v5.0
|
|
27
|
-
*/
|
|
28
|
-
export const TUI_DEFAULT_INPUT_COLORS = new Map([
|
|
29
|
-
['color-black-100', '#909090'],
|
|
30
|
-
['color-black-200', '#666666'],
|
|
31
|
-
['color-black-300', '#333333'],
|
|
32
|
-
['color-blue-100', '#1771e6'],
|
|
33
|
-
['color-blue-200', '#1464cc'],
|
|
34
|
-
['color-blue-300', '#0953b3'],
|
|
35
|
-
['color-gray-100', '#f5f5f6'],
|
|
36
|
-
['color-gray-200', '#e7e8ea'],
|
|
37
|
-
['color-gray-300', '#cbcfd3'],
|
|
38
|
-
['color-gray-400', '#959ba4'],
|
|
39
|
-
['color-gray-500', '#79818c'],
|
|
40
|
-
['color-gray-600', '#616871'],
|
|
41
|
-
['color-green-100', '#39b54a'],
|
|
42
|
-
['color-green-200', '#2ca53a'],
|
|
43
|
-
['color-green-300', '#168a21'],
|
|
44
|
-
['color-light-blue-100', '#ecf1f7'],
|
|
45
|
-
['color-light-blue-200', '#e4ebf3'],
|
|
46
|
-
['color-light-blue-300', '#dde4ed'],
|
|
47
|
-
['color-red-100', '#e01f19'],
|
|
48
|
-
['color-red-200', '#d3120e'],
|
|
49
|
-
['color-red-300', '#c40b08'],
|
|
50
|
-
['color-yellow-100', '#FFDD2C'],
|
|
51
|
-
['color-yellow-200', '#FCC521'],
|
|
52
|
-
['color-yellow-300', '#FAB618'],
|
|
53
|
-
['transparent', 'transparent'],
|
|
54
|
-
]);
|
|
55
|
-
const EMPTY_STOP = [0, 0, 0, 0];
|
|
56
|
-
const DEFAULT_STEPS = [
|
|
57
|
-
[0, [0, 0, 0, 1]],
|
|
58
|
-
[1, [255, 255, 255, 1]],
|
|
59
|
-
];
|
|
60
|
-
const ICONS = {
|
|
61
|
-
'to top right': 'tuiIconArrowUpRight',
|
|
62
|
-
'to right': 'tuiIconArrowRight',
|
|
63
|
-
'to bottom right': 'tuiIconArrowDownRight',
|
|
64
|
-
'to bottom': 'tuiIconArrowDown',
|
|
65
|
-
'to bottom left': 'tuiIconArrowDownLeft',
|
|
66
|
-
'to left': 'tuiIconArrowLeft',
|
|
67
|
-
'to top left': 'tuiIconArrowUpLeft',
|
|
68
|
-
'to top': 'tuiIconArrowUp',
|
|
69
|
-
};
|
|
70
20
|
/**
|
|
71
21
|
* @deprecated: drop in v5.0
|
|
72
22
|
*/
|
|
73
23
|
class TuiColorSelectorComponent {
|
|
74
24
|
constructor() {
|
|
75
|
-
this.
|
|
76
|
-
this.
|
|
77
|
-
this.
|
|
25
|
+
this.selectorOptions = inject(TUI_COLOR_SELECTOR_OPTIONS);
|
|
26
|
+
this.stops = new Map(this.selectorOptions.gradient.steps);
|
|
27
|
+
this.currentStop = this.selectorOptions.gradient.stop;
|
|
28
|
+
this.direction = this.selectorOptions.gradient.direction;
|
|
78
29
|
this.sanitizer = inject(DomSanitizer);
|
|
79
|
-
this.
|
|
30
|
+
this.open = false;
|
|
31
|
+
this.colors = this.selectorOptions.colors;
|
|
80
32
|
this.colorChange = new EventEmitter();
|
|
81
|
-
this.color =
|
|
33
|
+
this.color = this.selectorOptions.color;
|
|
82
34
|
this.modes = inject(TUI_COLOR_SELECTOR_MODE_NAMES);
|
|
83
|
-
this.currentMode = this.modes[
|
|
84
|
-
this.buttons =
|
|
85
|
-
'to top right',
|
|
86
|
-
'to right',
|
|
87
|
-
'to bottom right',
|
|
88
|
-
'to bottom',
|
|
89
|
-
'to bottom left',
|
|
90
|
-
'to left',
|
|
91
|
-
'to top left',
|
|
92
|
-
'to top',
|
|
93
|
-
];
|
|
35
|
+
this.currentMode = this.modes[this.selectorOptions.mode];
|
|
36
|
+
this.buttons = this.selectorOptions.gradient.buttons;
|
|
94
37
|
}
|
|
95
38
|
set colorSetter(color) {
|
|
96
|
-
|
|
39
|
+
if (color.startsWith('linear-gradient')) {
|
|
40
|
+
this.parseGradient(color);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
this.parseColor(color);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
get selectorMode() {
|
|
47
|
+
return this.selectorOptions.selectorMode;
|
|
97
48
|
}
|
|
98
49
|
get palette() {
|
|
99
50
|
return this.filterPalette(this.colors, this.isGradient);
|
|
@@ -108,10 +59,10 @@ class TuiColorSelectorComponent {
|
|
|
108
59
|
return this.sanitizer.bypassSecurityTrustStyle(this.getGradient('to right'));
|
|
109
60
|
}
|
|
110
61
|
get isGradient() {
|
|
111
|
-
return this.currentMode === this.modes[
|
|
62
|
+
return this.currentMode === this.modes[TuiColorSelectorMode.Gradient];
|
|
112
63
|
}
|
|
113
64
|
getIcon(direction) {
|
|
114
|
-
return
|
|
65
|
+
return this.selectorOptions.gradient.icons[direction];
|
|
115
66
|
}
|
|
116
67
|
isModeActive(mode) {
|
|
117
68
|
return this.currentMode === mode;
|
|
@@ -128,7 +79,8 @@ class TuiColorSelectorComponent {
|
|
|
128
79
|
}
|
|
129
80
|
onModeSelect(mode) {
|
|
130
81
|
this.currentMode = mode;
|
|
131
|
-
this.
|
|
82
|
+
this.open = false;
|
|
83
|
+
this.updateColor(mode === this.modes[TuiColorSelectorMode.SolidColor]
|
|
132
84
|
? `rgba(${this.color.join(', ')})`
|
|
133
85
|
: this.getGradient(this.direction));
|
|
134
86
|
}
|
|
@@ -180,7 +132,7 @@ class TuiColorSelectorComponent {
|
|
|
180
132
|
.join(', ')})`;
|
|
181
133
|
}
|
|
182
134
|
getStop(stop) {
|
|
183
|
-
return this.stops.get(stop) ||
|
|
135
|
+
return this.stops.get(stop) || this.selectorOptions.gradient.emptyStop;
|
|
184
136
|
}
|
|
185
137
|
addStop(stop) {
|
|
186
138
|
const closest = this.stopsKeys.reduce((prev, curr) => (Math.abs(curr - stop) < Math.abs(prev - stop) ? curr : prev), this.stopsKeys[0]);
|
|
@@ -198,36 +150,26 @@ class TuiColorSelectorComponent {
|
|
|
198
150
|
this.currentStop = added;
|
|
199
151
|
this.stops = new Map(this.stopsKeys.map((key) => key === removed ? [added, value] : [key, this.getStop(key)]));
|
|
200
152
|
}
|
|
201
|
-
parse(color) {
|
|
202
|
-
if (color.startsWith('linear-gradient')) {
|
|
203
|
-
this.parseGradient(color);
|
|
204
|
-
}
|
|
205
|
-
else {
|
|
206
|
-
this.parseColor(color);
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
153
|
parseGradient(color) {
|
|
210
154
|
if (color === this.getGradient(this.direction)) {
|
|
211
155
|
return;
|
|
212
156
|
}
|
|
213
157
|
const gradient = tuiParseGradient(tuiGetGradientData(color));
|
|
214
|
-
this.currentMode = this.modes[1];
|
|
215
158
|
this.direction = gradient.side;
|
|
216
|
-
this.currentStop =
|
|
159
|
+
this.currentStop = this.selectorOptions.gradient.stop;
|
|
217
160
|
this.stops = new Map(gradient.stops.length
|
|
218
161
|
? gradient.stops.map(({ color, position }) => [
|
|
219
162
|
parseFloat(position) / 100,
|
|
220
163
|
tuiParseColor(color),
|
|
221
164
|
])
|
|
222
|
-
:
|
|
165
|
+
: this.selectorOptions.gradient.steps);
|
|
223
166
|
}
|
|
224
167
|
parseColor(color) {
|
|
225
|
-
this.
|
|
226
|
-
this.currentStop = 0;
|
|
168
|
+
this.currentStop = this.selectorOptions.gradient.stop;
|
|
227
169
|
this.color = tuiParseColor(color);
|
|
228
170
|
}
|
|
229
171
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiColorSelectorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
230
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiColorSelectorComponent, selector: "tui-color-selector", inputs: { colors: "colors", colorSetter: ["color", "colorSetter"] }, outputs: { colorChange: "colorChange" }, ngImport: i0, template: "<div\n
|
|
172
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiColorSelectorComponent, selector: "tui-color-selector", inputs: { colors: "colors", colorSetter: ["color", "colorSetter"] }, outputs: { colorChange: "colorChange" }, ngImport: i0, template: "<ng-container *ngIf=\"selectorMode\">\n <div\n class=\"t-select\"\n [tuiDropdown]=\"menu\"\n [(tuiDropdownOpen)]=\"open\"\n >\n <button\n appearance=\"\"\n size=\"s\"\n tuiButton\n tuiChevron\n type=\"button\"\n >\n {{ currentMode }}\n </button>\n\n <ng-template #menu>\n <tui-data-list\n role=\"menu\"\n size=\"s\"\n class=\"t-menu\"\n >\n <button\n *ngFor=\"let mode of modes\"\n role=\"menuitemradio\"\n tuiOption\n [attr.aria-checked]=\"isModeActive(mode)\"\n (click)=\"onModeSelect(mode)\"\n (keydown.enter.prevent)=\"onModeSelect(mode)\"\n (keydown.space.prevent)=\"onModeSelect(mode)\"\n >\n {{ mode }}\n <tui-icon\n *ngIf=\"isModeActive(mode)\"\n icon=\"@tui.check\"\n class=\"t-checkmark\"\n />\n </button>\n </tui-data-list>\n </ng-template>\n </div>\n <hr class=\"t-hr\" />\n</ng-container>\n\n<ng-container *ngIf=\"isGradient\">\n <div\n class=\"t-wrapper\"\n [style.background]=\"gradient\"\n >\n <tui-linear-multi-picker\n class=\"t-gradient\"\n [value]=\"stopsKeys\"\n (indexChange)=\"onIndexChange($event)\"\n (valueChange)=\"onStopsChange($event)\"\n />\n </div>\n <div class=\"t-buttons\">\n <!-- TODO: Change to `tuiHintDescribe` when figure tuiDriver order issue -->\n <button\n *ngFor=\"let button of buttons\"\n appearance=\"\"\n size=\"xs\"\n tuiHintDescribe\n tuiIconButton\n type=\"button\"\n class=\"t-direction\"\n [class.t-direction_active]=\"isDirectionActive(button)\"\n [iconStart]=\"getIcon(button)\"\n [tuiHint]=\"button\"\n (click)=\"onDirectionChange(button)\"\n ></button>\n </div>\n</ng-container>\n<tui-color-picker\n [color]=\"currentColor\"\n (colorChange)=\"onColorChange($event)\"\n/>\n<tui-color-edit\n *ngIf=\"!isGradient\"\n tuiGroup\n class=\"t-edit\"\n [color]=\"color\"\n (colorChange)=\"onColorChange($event)\"\n/>\n<tui-palette\n *ngIf=\"palette.size\"\n class=\"t-palette\"\n [colors]=\"palette\"\n (selectedColor)=\"onPalettePick($event)\"\n/>\n", styles: [":host{position:relative;display:block;isolation:isolate;width:22.6rem}.t-wrapper{position:relative;margin:1.25rem;border-radius:.5rem}.t-wrapper:after{position:absolute;top:0;left:0;width:100%;height:100%;content:\"\";box-shadow:inset 0 0 0 1px #00000014;pointer-events:none;border-radius:inherit}.t-wrapper:before{position:absolute;top:0;left:0;width:100%;height:100%;content:\"\";z-index:-1;background-image:linear-gradient(45deg,var(--tui-base-03) 25%,transparent 25%,transparent 75%,var(--tui-base-03) 75%,var(--tui-base-03)),linear-gradient(45deg,var(--tui-base-03) 25%,transparent 25%,transparent 75%,var(--tui-base-03) 75%,var(--tui-base-03));background-size:.375rem .375rem;background-position:0 0,.1875rem .1875rem;border-radius:inherit}.t-hr{height:1px;margin:0 0 0 -1px;border:none;background:var(--tui-base-03)}.t-gradient{margin:0 .5rem;border-radius:inherit}.t-select{margin:.75rem .5rem 0}.t-arrow{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out}.t-arrow_rotated{transform:rotate(180deg)}.t-menu{width:11.25rem}.t-checkmark{margin-left:auto;width:1rem;height:1rem}.t-buttons{display:flex;padding:0 .75rem 1.25rem;justify-content:space-between}.t-direction{color:var(--tui-text-02);margin:0 .375rem}.t-direction:hover,.t-direction_active{color:var(--tui-text-01);background:var(--tui-secondary-hover)}.t-edit{margin:1.25rem}.t-palette{box-sizing:border-box;box-shadow:inset 0 1px var(--tui-base-03)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }, { kind: "component", type: i3.TuiColorPickerComponent, selector: "tui-color-picker", inputs: ["color"], outputs: ["colorChange"] }, { kind: "component", type: i4.TuiLinearMultiPickerComponent, selector: "tui-linear-multi-picker", inputs: ["value"], outputs: ["valueChange", "indexChange"] }, { kind: "component", type: i5.TuiColorEditComponent, selector: "tui-color-edit", inputs: ["color"], outputs: ["colorChange"] }, { kind: "directive", type: i6.TuiDropdownDirective, selector: "[tuiDropdown]:not(ng-container):not(ng-template)", inputs: ["tuiDropdown"], exportAs: ["tuiDropdown"] }, { kind: "directive", type: i6.TuiDropdownOpen, selector: "[tuiDropdown][tuiDropdownOpen],[tuiDropdown][tuiDropdownOpenChange]", inputs: ["tuiDropdownEnabled", "tuiDropdownOpen"], outputs: ["tuiDropdownOpenChange"] }, { kind: "component", type: i7.TuiDataListComponent, selector: "tui-data-list", inputs: ["emptyContent", "size"] }, { kind: "component", type: i7.TuiOption, selector: "button[tuiOption], a[tuiOption], label[tuiOption]", inputs: ["disabled", "value"] }, { kind: "directive", type: i8.TuiGroup, selector: "[tuiGroup]:not(ng-container)", inputs: ["orientation", "collapsed", "rounded", "size"] }, { kind: "component", type: i9.TuiPaletteComponent, selector: "tui-palette", inputs: ["colors"], outputs: ["selectedColor"] }, { kind: "directive", type: i10.TuiHintDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHintContext", "tuiHintAppearance", "tuiHint"] }, { kind: "directive", type: i10.TuiHintDescribe, selector: "[tuiHintDescribe]", inputs: ["tuiHintDescribe"] }, { kind: "directive", type: i11.TuiChevron, selector: "[tuiChevron]", inputs: ["tuiChevron"] }, { kind: "component", type: i12.TuiIcon, selector: "tui-icon", inputs: ["icon", "background"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
231
173
|
}
|
|
232
174
|
__decorate([
|
|
233
175
|
tuiPure
|
|
@@ -238,7 +180,7 @@ __decorate([
|
|
|
238
180
|
export { TuiColorSelectorComponent };
|
|
239
181
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiColorSelectorComponent, decorators: [{
|
|
240
182
|
type: Component,
|
|
241
|
-
args: [{ selector: 'tui-color-selector', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n
|
|
183
|
+
args: [{ selector: 'tui-color-selector', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"selectorMode\">\n <div\n class=\"t-select\"\n [tuiDropdown]=\"menu\"\n [(tuiDropdownOpen)]=\"open\"\n >\n <button\n appearance=\"\"\n size=\"s\"\n tuiButton\n tuiChevron\n type=\"button\"\n >\n {{ currentMode }}\n </button>\n\n <ng-template #menu>\n <tui-data-list\n role=\"menu\"\n size=\"s\"\n class=\"t-menu\"\n >\n <button\n *ngFor=\"let mode of modes\"\n role=\"menuitemradio\"\n tuiOption\n [attr.aria-checked]=\"isModeActive(mode)\"\n (click)=\"onModeSelect(mode)\"\n (keydown.enter.prevent)=\"onModeSelect(mode)\"\n (keydown.space.prevent)=\"onModeSelect(mode)\"\n >\n {{ mode }}\n <tui-icon\n *ngIf=\"isModeActive(mode)\"\n icon=\"@tui.check\"\n class=\"t-checkmark\"\n />\n </button>\n </tui-data-list>\n </ng-template>\n </div>\n <hr class=\"t-hr\" />\n</ng-container>\n\n<ng-container *ngIf=\"isGradient\">\n <div\n class=\"t-wrapper\"\n [style.background]=\"gradient\"\n >\n <tui-linear-multi-picker\n class=\"t-gradient\"\n [value]=\"stopsKeys\"\n (indexChange)=\"onIndexChange($event)\"\n (valueChange)=\"onStopsChange($event)\"\n />\n </div>\n <div class=\"t-buttons\">\n <!-- TODO: Change to `tuiHintDescribe` when figure tuiDriver order issue -->\n <button\n *ngFor=\"let button of buttons\"\n appearance=\"\"\n size=\"xs\"\n tuiHintDescribe\n tuiIconButton\n type=\"button\"\n class=\"t-direction\"\n [class.t-direction_active]=\"isDirectionActive(button)\"\n [iconStart]=\"getIcon(button)\"\n [tuiHint]=\"button\"\n (click)=\"onDirectionChange(button)\"\n ></button>\n </div>\n</ng-container>\n<tui-color-picker\n [color]=\"currentColor\"\n (colorChange)=\"onColorChange($event)\"\n/>\n<tui-color-edit\n *ngIf=\"!isGradient\"\n tuiGroup\n class=\"t-edit\"\n [color]=\"color\"\n (colorChange)=\"onColorChange($event)\"\n/>\n<tui-palette\n *ngIf=\"palette.size\"\n class=\"t-palette\"\n [colors]=\"palette\"\n (selectedColor)=\"onPalettePick($event)\"\n/>\n", styles: [":host{position:relative;display:block;isolation:isolate;width:22.6rem}.t-wrapper{position:relative;margin:1.25rem;border-radius:.5rem}.t-wrapper:after{position:absolute;top:0;left:0;width:100%;height:100%;content:\"\";box-shadow:inset 0 0 0 1px #00000014;pointer-events:none;border-radius:inherit}.t-wrapper:before{position:absolute;top:0;left:0;width:100%;height:100%;content:\"\";z-index:-1;background-image:linear-gradient(45deg,var(--tui-base-03) 25%,transparent 25%,transparent 75%,var(--tui-base-03) 75%,var(--tui-base-03)),linear-gradient(45deg,var(--tui-base-03) 25%,transparent 25%,transparent 75%,var(--tui-base-03) 75%,var(--tui-base-03));background-size:.375rem .375rem;background-position:0 0,.1875rem .1875rem;border-radius:inherit}.t-hr{height:1px;margin:0 0 0 -1px;border:none;background:var(--tui-base-03)}.t-gradient{margin:0 .5rem;border-radius:inherit}.t-select{margin:.75rem .5rem 0}.t-arrow{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out}.t-arrow_rotated{transform:rotate(180deg)}.t-menu{width:11.25rem}.t-checkmark{margin-left:auto;width:1rem;height:1rem}.t-buttons{display:flex;padding:0 .75rem 1.25rem;justify-content:space-between}.t-direction{color:var(--tui-text-02);margin:0 .375rem}.t-direction:hover,.t-direction_active{color:var(--tui-text-01);background:var(--tui-secondary-hover)}.t-edit{margin:1.25rem}.t-palette{box-sizing:border-box;box-shadow:inset 0 1px var(--tui-base-03)}\n"] }]
|
|
242
184
|
}], propDecorators: { colors: [{
|
|
243
185
|
type: Input
|
|
244
186
|
}], colorChange: [{
|
|
@@ -247,4 +189,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
247
189
|
type: Input,
|
|
248
190
|
args: ['color']
|
|
249
191
|
}], getStopsKeys: [], filterPalette: [] } });
|
|
250
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-selector.component.js","sourceRoot":"","sources":["../../../../../projects/legacy/components/color-selector/color-selector.component.ts","../../../../../projects/legacy/components/color-selector/color-selector.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    InjectionToken,\n    Input,\n    Output,\n} from '@angular/core';\nimport type {SafeStyle} from '@angular/platform-browser';\nimport {DomSanitizer} from '@angular/platform-browser';\nimport type {TuiGradientDirection} from '@taiga-ui/cdk/utils/color';\nimport {\n    tuiGetGradientData,\n    tuiParseColor,\n    tuiParseGradient,\n} from '@taiga-ui/cdk/utils/color';\nimport {tuiDefaultSort, tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\n\n/**\n * @deprecated: drop in v5.0\n */\nexport const TUI_COLOR_SELECTOR_MODE_NAMES = new InjectionToken<[string, string]>(\n    '[TUI_COLOR_SELECTOR_MODE_NAMES]',\n    {\n        factory: () => ['Solid color', 'Gradient'],\n    },\n);\n\n/**\n * @deprecated: drop in v5.0\n */\nexport const TUI_DEFAULT_INPUT_COLORS = new Map([\n    ['color-black-100', '#909090'],\n    ['color-black-200', '#666666'],\n    ['color-black-300', '#333333'],\n    ['color-blue-100', '#1771e6'],\n    ['color-blue-200', '#1464cc'],\n    ['color-blue-300', '#0953b3'],\n    ['color-gray-100', '#f5f5f6'],\n    ['color-gray-200', '#e7e8ea'],\n    ['color-gray-300', '#cbcfd3'],\n    ['color-gray-400', '#959ba4'],\n    ['color-gray-500', '#79818c'],\n    ['color-gray-600', '#616871'],\n    ['color-green-100', '#39b54a'],\n    ['color-green-200', '#2ca53a'],\n    ['color-green-300', '#168a21'],\n    ['color-light-blue-100', '#ecf1f7'],\n    ['color-light-blue-200', '#e4ebf3'],\n    ['color-light-blue-300', '#dde4ed'],\n    ['color-red-100', '#e01f19'],\n    ['color-red-200', '#d3120e'],\n    ['color-red-300', '#c40b08'],\n    ['color-yellow-100', '#FFDD2C'],\n    ['color-yellow-200', '#FCC521'],\n    ['color-yellow-300', '#FAB618'],\n    ['transparent', 'transparent'],\n]);\n\nconst EMPTY_STOP: [number, number, number, number] = [0, 0, 0, 0];\n\nconst DEFAULT_STEPS: ReadonlyArray<[number, [number, number, number, number]]> = [\n    [0, [0, 0, 0, 1]],\n    [1, [255, 255, 255, 1]],\n];\n\nconst ICONS: Record<TuiGradientDirection, string> = {\n    'to top right': 'tuiIconArrowUpRight',\n    'to right': 'tuiIconArrowRight',\n    'to bottom right': 'tuiIconArrowDownRight',\n    'to bottom': 'tuiIconArrowDown',\n    'to bottom left': 'tuiIconArrowDownLeft',\n    'to left': 'tuiIconArrowLeft',\n    'to top left': 'tuiIconArrowUpLeft',\n    'to top': 'tuiIconArrowUp',\n};\n\n/**\n * @deprecated: drop in v5.0\n */\n@Component({\n    selector: 'tui-color-selector',\n    templateUrl: './color-selector.template.html',\n    styleUrls: ['./color-selector.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiColorSelectorComponent {\n    private stops = new Map(DEFAULT_STEPS);\n    private currentStop = 0;\n    private direction: TuiGradientDirection = 'to bottom';\n    private readonly sanitizer = inject(DomSanitizer);\n\n    @Input()\n    public colors: ReadonlyMap<string, string> = new Map<string, string>();\n\n    @Output()\n    public readonly colorChange = new EventEmitter<string>();\n\n    public color: [number, number, number, number] = [0, 0, 0, 1];\n\n    public readonly modes = inject(TUI_COLOR_SELECTOR_MODE_NAMES);\n\n    public currentMode = this.modes[0];\n\n    public readonly buttons: readonly TuiGradientDirection[] = [\n        'to top right',\n        'to right',\n        'to bottom right',\n        'to bottom',\n        'to bottom left',\n        'to left',\n        'to top left',\n        'to top',\n    ];\n\n    @Input('color')\n    public set colorSetter(color: string) {\n        this.parse(color);\n    }\n\n    public get palette(): Map<string, string> {\n        return this.filterPalette(this.colors, this.isGradient);\n    }\n\n    public get stopsKeys(): number[] {\n        return this.getStopsKeys(this.stops);\n    }\n\n    public get currentColor(): [number, number, number, number] {\n        return this.isGradient ? this.getStop(this.currentStop) : this.color;\n    }\n\n    public get gradient(): SafeStyle {\n        return this.sanitizer.bypassSecurityTrustStyle(this.getGradient('to right'));\n    }\n\n    public get isGradient(): boolean {\n        return this.currentMode === this.modes[1];\n    }\n\n    public getIcon(direction: TuiGradientDirection): string {\n        return ICONS[direction];\n    }\n\n    public isModeActive(mode: string): boolean {\n        return this.currentMode === mode;\n    }\n\n    public isDirectionActive(direction: TuiGradientDirection): boolean {\n        return this.direction === direction;\n    }\n\n    public onPalettePick(color: string): void {\n        this.updateColor(color);\n    }\n\n    public onDirectionChange(direction: TuiGradientDirection): void {\n        this.direction = direction;\n        this.updateColor(this.getGradient(direction));\n    }\n\n    public onModeSelect(mode: string): void {\n        this.currentMode = mode;\n\n        this.updateColor(\n            mode === this.modes[0]\n                ? `rgba(${this.color.join(', ')})`\n                : this.getGradient(this.direction),\n        );\n    }\n\n    public onIndexChange(index: number): void {\n        this.currentStop = this.stopsKeys[index];\n    }\n\n    public onColorChange(color: [number, number, number, number]): void {\n        if (!this.isGradient) {\n            this.updateColor(`rgba(${color.join(', ')})`);\n\n            return;\n        }\n\n        this.stops.set(this.currentStop, color);\n        this.updateColor(this.getGradient(this.direction));\n    }\n\n    public onStopsChange(stopsKeys: readonly number[]): void {\n        const removed = this.stopsKeys.find((item) => !stopsKeys.includes(item));\n        const added = stopsKeys.find((item) => !this.stopsKeys.includes(item));\n\n        if (removed === undefined && added !== undefined) {\n            this.addStop(added);\n        }\n\n        if (removed !== undefined && added === undefined) {\n            this.removeStop(removed);\n        }\n\n        if (removed !== undefined && added !== undefined) {\n            this.replaceStop(removed, added);\n        }\n\n        this.updateColor(this.getGradient(this.direction));\n    }\n\n    @tuiPure\n    private getStopsKeys(stops: Map<number, unknown>): number[] {\n        return Array.from(stops.keys());\n    }\n\n    @tuiPure\n    private filterPalette(\n        colors: ReadonlyMap<string, string>,\n        isGradient: boolean,\n    ): Map<string, string> {\n        const map = new Map(colors);\n\n        map.forEach((value, key) => {\n            if (\n                (value.startsWith('linear-gradient') && !isGradient) ||\n                (!value.startsWith('linear-gradient') && isGradient)\n            ) {\n                map.delete(key);\n            }\n        });\n\n        return map;\n    }\n\n    private updateColor(color: string): void {\n        this.colorChange.emit(color);\n    }\n\n    private getGradient(direction: TuiGradientDirection): string {\n        return `linear-gradient(${direction}, ${[...this.stopsKeys]\n            .sort(tuiDefaultSort)\n            .map((key) => `rgba(${this.getStop(key).join(', ')}) ${key * 100}%`)\n            .join(', ')})`;\n    }\n\n    private getStop(stop: number): [number, number, number, number] {\n        return this.stops.get(stop) || EMPTY_STOP;\n    }\n\n    private addStop(stop: number): void {\n        const closest = this.stopsKeys.reduce(\n            (prev, curr) => (Math.abs(curr - stop) < Math.abs(prev - stop) ? curr : prev),\n            this.stopsKeys[0],\n        );\n\n        this.stops.set(stop, this.getStop(closest));\n        this.stops = new Map(this.stops);\n        this.currentStop = stop;\n    }\n\n    private removeStop(stop: number): void {\n        this.stops.delete(stop);\n        this.stops = new Map(this.stops);\n        this.currentStop = this.stopsKeys[0];\n    }\n\n    private replaceStop(removed: number, added: number): void {\n        const value = this.getStop(removed);\n\n        this.currentStop = added;\n        this.stops = new Map(\n            this.stopsKeys.map<[number, [number, number, number, number]]>((key) =>\n                key === removed ? [added, value] : [key, this.getStop(key)],\n            ),\n        );\n    }\n\n    private parse(color: string): void {\n        if (color.startsWith('linear-gradient')) {\n            this.parseGradient(color);\n        } else {\n            this.parseColor(color);\n        }\n    }\n\n    private parseGradient(color: string): void {\n        if (color === this.getGradient(this.direction)) {\n            return;\n        }\n\n        const gradient = tuiParseGradient(tuiGetGradientData(color));\n\n        this.currentMode = this.modes[1];\n        this.direction = gradient.side;\n        this.currentStop = 0;\n        this.stops = new Map(\n            gradient.stops.length\n                ? gradient.stops.map<[number, [number, number, number, number]]>(\n                      ({color, position}) => [\n                          parseFloat(position) / 100,\n                          tuiParseColor(color),\n                      ],\n                  )\n                : DEFAULT_STEPS,\n        );\n    }\n\n    private parseColor(color: string): void {\n        this.currentMode = this.modes[0];\n        this.currentStop = 0;\n        this.color = tuiParseColor(color);\n    }\n}\n","<div\n    class=\"t-select\"\n    [tuiDropdown]=\"menu\"\n    [tuiDropdownOpen]=\"false\"\n>\n    <button\n        appearance=\"\"\n        size=\"s\"\n        tuiButton\n        tuiChevron\n        type=\"button\"\n    >\n        {{ currentMode }}\n    </button>\n\n    <ng-template #menu>\n        <tui-data-list\n            role=\"menu\"\n            size=\"s\"\n            class=\"t-menu\"\n        >\n            <button\n                *ngFor=\"let mode of modes\"\n                role=\"menuitemradio\"\n                tuiOption\n                [attr.aria-checked]=\"isModeActive(mode)\"\n                (click)=\"onModeSelect(mode)\"\n                (keydown.enter.prevent)=\"onModeSelect(mode)\"\n                (keydown.space.prevent)=\"onModeSelect(mode)\"\n            >\n                {{ mode }}\n                <tui-icon\n                    *ngIf=\"isModeActive(mode)\"\n                    icon=\"@tui.check\"\n                    class=\"t-checkmark\"\n                />\n            </button>\n        </tui-data-list>\n    </ng-template>\n</div>\n<ng-container *ngIf=\"isGradient\">\n    <hr class=\"t-hr\" />\n    <div\n        class=\"t-wrapper\"\n        [style.background]=\"gradient\"\n    >\n        <tui-linear-multi-picker\n            class=\"t-gradient\"\n            [value]=\"stopsKeys\"\n            (indexChange)=\"onIndexChange($event)\"\n            (valueChange)=\"onStopsChange($event)\"\n        />\n    </div>\n    <div class=\"t-buttons\">\n        <!-- TODO: Change to `tuiHintDescribe` when figure tuiDriver order issue -->\n        <button\n            *ngFor=\"let button of buttons\"\n            appearance=\"\"\n            size=\"xs\"\n            tuiHintDescribe\n            tuiIconButton\n            type=\"button\"\n            class=\"t-direction\"\n            [class.t-direction_active]=\"isDirectionActive(button)\"\n            [iconStart]=\"getIcon(button)\"\n            [tuiHint]=\"button\"\n            (click)=\"onDirectionChange(button)\"\n        ></button>\n    </div>\n</ng-container>\n<tui-color-picker\n    [color]=\"currentColor\"\n    (colorChange)=\"onColorChange($event)\"\n/>\n<tui-color-edit\n    *ngIf=\"!isGradient\"\n    tuiGroup\n    class=\"t-edit\"\n    [color]=\"color\"\n    (colorChange)=\"onColorChange($event)\"\n/>\n<tui-palette\n    *ngIf=\"palette.size\"\n    class=\"t-palette\"\n    [colors]=\"palette\"\n    (selectedColor)=\"onPalettePick($event)\"\n/>\n"]}
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-selector.component.js","sourceRoot":"","sources":["../../../../../projects/legacy/components/color-selector/color-selector.component.ts","../../../../../projects/legacy/components/color-selector/color-selector.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n} from '@angular/core';\nimport type {SafeStyle} from '@angular/platform-browser';\nimport {DomSanitizer} from '@angular/platform-browser';\nimport type {TuiGradientDirection} from '@taiga-ui/cdk/utils/color';\nimport {\n    tuiGetGradientData,\n    tuiParseColor,\n    tuiParseGradient,\n} from '@taiga-ui/cdk/utils/color';\nimport {tuiDefaultSort, tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\n\nimport {\n    TUI_COLOR_SELECTOR_MODE_NAMES,\n    TUI_COLOR_SELECTOR_OPTIONS,\n    TuiColorSelectorMode,\n} from './color-selector.options';\n\n/**\n * @deprecated: drop in v5.0\n */\n@Component({\n    selector: 'tui-color-selector',\n    templateUrl: './color-selector.template.html',\n    styleUrls: ['./color-selector.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiColorSelectorComponent {\n    private readonly selectorOptions = inject(TUI_COLOR_SELECTOR_OPTIONS);\n    private stops = new Map(this.selectorOptions.gradient.steps);\n    private currentStop = this.selectorOptions.gradient.stop;\n    private direction = this.selectorOptions.gradient.direction;\n\n    private readonly sanitizer = inject(DomSanitizer);\n    protected open = false;\n\n    @Input()\n    public colors = this.selectorOptions.colors;\n\n    @Output()\n    public readonly colorChange = new EventEmitter<string>();\n\n    public color = this.selectorOptions.color;\n\n    public readonly modes = inject(TUI_COLOR_SELECTOR_MODE_NAMES);\n\n    public currentMode = this.modes[this.selectorOptions.mode];\n\n    public readonly buttons = this.selectorOptions.gradient.buttons;\n\n    @Input('color')\n    public set colorSetter(color: string) {\n        if (color.startsWith('linear-gradient')) {\n            this.parseGradient(color);\n        } else {\n            this.parseColor(color);\n        }\n    }\n\n    public get selectorMode(): boolean {\n        return this.selectorOptions.selectorMode;\n    }\n\n    public get palette(): Map<string, string> {\n        return this.filterPalette(this.colors, this.isGradient);\n    }\n\n    public get stopsKeys(): number[] {\n        return this.getStopsKeys(this.stops);\n    }\n\n    public get currentColor(): [number, number, number, number] {\n        return this.isGradient ? this.getStop(this.currentStop) : this.color;\n    }\n\n    public get gradient(): SafeStyle {\n        return this.sanitizer.bypassSecurityTrustStyle(this.getGradient('to right'));\n    }\n\n    public get isGradient(): boolean {\n        return this.currentMode === this.modes[TuiColorSelectorMode.Gradient];\n    }\n\n    public getIcon(direction: TuiGradientDirection): string {\n        return this.selectorOptions.gradient.icons[direction];\n    }\n\n    public isModeActive(mode: string): boolean {\n        return this.currentMode === mode;\n    }\n\n    public isDirectionActive(direction: TuiGradientDirection): boolean {\n        return this.direction === direction;\n    }\n\n    public onPalettePick(color: string): void {\n        this.updateColor(color);\n    }\n\n    public onDirectionChange(direction: TuiGradientDirection): void {\n        this.direction = direction;\n        this.updateColor(this.getGradient(direction));\n    }\n\n    public onModeSelect(mode: string): void {\n        this.currentMode = mode;\n        this.open = false;\n\n        this.updateColor(\n            mode === this.modes[TuiColorSelectorMode.SolidColor]\n                ? `rgba(${this.color.join(', ')})`\n                : this.getGradient(this.direction),\n        );\n    }\n\n    public onIndexChange(index: number): void {\n        this.currentStop = this.stopsKeys[index];\n    }\n\n    public onColorChange(color: [number, number, number, number]): void {\n        if (!this.isGradient) {\n            this.updateColor(`rgba(${color.join(', ')})`);\n\n            return;\n        }\n\n        this.stops.set(this.currentStop, color);\n        this.updateColor(this.getGradient(this.direction));\n    }\n\n    public onStopsChange(stopsKeys: readonly number[]): void {\n        const removed = this.stopsKeys.find((item) => !stopsKeys.includes(item));\n        const added = stopsKeys.find((item) => !this.stopsKeys.includes(item));\n\n        if (removed === undefined && added !== undefined) {\n            this.addStop(added);\n        }\n\n        if (removed !== undefined && added === undefined) {\n            this.removeStop(removed);\n        }\n\n        if (removed !== undefined && added !== undefined) {\n            this.replaceStop(removed, added);\n        }\n\n        this.updateColor(this.getGradient(this.direction));\n    }\n\n    @tuiPure\n    private getStopsKeys(stops: Map<number, unknown>): number[] {\n        return Array.from(stops.keys());\n    }\n\n    @tuiPure\n    private filterPalette(\n        colors: ReadonlyMap<string, string>,\n        isGradient: boolean,\n    ): Map<string, string> {\n        const map = new Map(colors);\n\n        map.forEach((value, key) => {\n            if (\n                (value.startsWith('linear-gradient') && !isGradient) ||\n                (!value.startsWith('linear-gradient') && isGradient)\n            ) {\n                map.delete(key);\n            }\n        });\n\n        return map;\n    }\n\n    private updateColor(color: string): void {\n        this.colorChange.emit(color);\n    }\n\n    private getGradient(direction: TuiGradientDirection): string {\n        return `linear-gradient(${direction}, ${[...this.stopsKeys]\n            .sort(tuiDefaultSort)\n            .map((key) => `rgba(${this.getStop(key).join(', ')}) ${key * 100}%`)\n            .join(', ')})`;\n    }\n\n    private getStop(stop: number): [number, number, number, number] {\n        return this.stops.get(stop) || this.selectorOptions.gradient.emptyStop;\n    }\n\n    private addStop(stop: number): void {\n        const closest = this.stopsKeys.reduce(\n            (prev, curr) => (Math.abs(curr - stop) < Math.abs(prev - stop) ? curr : prev),\n            this.stopsKeys[0],\n        );\n\n        this.stops.set(stop, this.getStop(closest));\n        this.stops = new Map(this.stops);\n        this.currentStop = stop;\n    }\n\n    private removeStop(stop: number): void {\n        this.stops.delete(stop);\n        this.stops = new Map(this.stops);\n        this.currentStop = this.stopsKeys[0];\n    }\n\n    private replaceStop(removed: number, added: number): void {\n        const value = this.getStop(removed);\n\n        this.currentStop = added;\n        this.stops = new Map(\n            this.stopsKeys.map<[number, [number, number, number, number]]>((key) =>\n                key === removed ? [added, value] : [key, this.getStop(key)],\n            ),\n        );\n    }\n\n    private parseGradient(color: string): void {\n        if (color === this.getGradient(this.direction)) {\n            return;\n        }\n\n        const gradient = tuiParseGradient(tuiGetGradientData(color));\n\n        this.direction = gradient.side;\n        this.currentStop = this.selectorOptions.gradient.stop;\n        this.stops = new Map(\n            gradient.stops.length\n                ? gradient.stops.map<[number, [number, number, number, number]]>(\n                      ({color, position}) => [\n                          parseFloat(position) / 100,\n                          tuiParseColor(color),\n                      ],\n                  )\n                : this.selectorOptions.gradient.steps,\n        );\n    }\n\n    private parseColor(color: string): void {\n        this.currentStop = this.selectorOptions.gradient.stop;\n        this.color = tuiParseColor(color);\n    }\n}\n","<ng-container *ngIf=\"selectorMode\">\n    <div\n        class=\"t-select\"\n        [tuiDropdown]=\"menu\"\n        [(tuiDropdownOpen)]=\"open\"\n    >\n        <button\n            appearance=\"\"\n            size=\"s\"\n            tuiButton\n            tuiChevron\n            type=\"button\"\n        >\n            {{ currentMode }}\n        </button>\n\n        <ng-template #menu>\n            <tui-data-list\n                role=\"menu\"\n                size=\"s\"\n                class=\"t-menu\"\n            >\n                <button\n                    *ngFor=\"let mode of modes\"\n                    role=\"menuitemradio\"\n                    tuiOption\n                    [attr.aria-checked]=\"isModeActive(mode)\"\n                    (click)=\"onModeSelect(mode)\"\n                    (keydown.enter.prevent)=\"onModeSelect(mode)\"\n                    (keydown.space.prevent)=\"onModeSelect(mode)\"\n                >\n                    {{ mode }}\n                    <tui-icon\n                        *ngIf=\"isModeActive(mode)\"\n                        icon=\"@tui.check\"\n                        class=\"t-checkmark\"\n                    />\n                </button>\n            </tui-data-list>\n        </ng-template>\n    </div>\n    <hr class=\"t-hr\" />\n</ng-container>\n\n<ng-container *ngIf=\"isGradient\">\n    <div\n        class=\"t-wrapper\"\n        [style.background]=\"gradient\"\n    >\n        <tui-linear-multi-picker\n            class=\"t-gradient\"\n            [value]=\"stopsKeys\"\n            (indexChange)=\"onIndexChange($event)\"\n            (valueChange)=\"onStopsChange($event)\"\n        />\n    </div>\n    <div class=\"t-buttons\">\n        <!-- TODO: Change to `tuiHintDescribe` when figure tuiDriver order issue -->\n        <button\n            *ngFor=\"let button of buttons\"\n            appearance=\"\"\n            size=\"xs\"\n            tuiHintDescribe\n            tuiIconButton\n            type=\"button\"\n            class=\"t-direction\"\n            [class.t-direction_active]=\"isDirectionActive(button)\"\n            [iconStart]=\"getIcon(button)\"\n            [tuiHint]=\"button\"\n            (click)=\"onDirectionChange(button)\"\n        ></button>\n    </div>\n</ng-container>\n<tui-color-picker\n    [color]=\"currentColor\"\n    (colorChange)=\"onColorChange($event)\"\n/>\n<tui-color-edit\n    *ngIf=\"!isGradient\"\n    tuiGroup\n    class=\"t-edit\"\n    [color]=\"color\"\n    (colorChange)=\"onColorChange($event)\"\n/>\n<tui-palette\n    *ngIf=\"palette.size\"\n    class=\"t-palette\"\n    [colors]=\"palette\"\n    (selectedColor)=\"onPalettePick($event)\"\n/>\n"]}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
import { tuiCreateToken, tuiProvideOptions } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
3
|
+
/**
|
|
4
|
+
* @deprecated: drop in v5.0
|
|
5
|
+
*/
|
|
6
|
+
export const TUI_COLOR_SELECTOR_MODE_NAMES = new InjectionToken('[TUI_COLOR_SELECTOR_MODE_NAMES]', {
|
|
7
|
+
factory: () => ['Solid color', 'Gradient'],
|
|
8
|
+
});
|
|
9
|
+
/**
|
|
10
|
+
* @deprecated: drop in v5.0
|
|
11
|
+
*/
|
|
12
|
+
export const TUI_DEFAULT_INPUT_COLORS = new Map([
|
|
13
|
+
['color-black-100', '#909090'],
|
|
14
|
+
['color-black-200', '#666666'],
|
|
15
|
+
['color-black-300', '#333333'],
|
|
16
|
+
['color-blue-100', '#1771e6'],
|
|
17
|
+
['color-blue-200', '#1464cc'],
|
|
18
|
+
['color-blue-300', '#0953b3'],
|
|
19
|
+
['color-gray-100', '#f5f5f6'],
|
|
20
|
+
['color-gray-200', '#e7e8ea'],
|
|
21
|
+
['color-gray-300', '#cbcfd3'],
|
|
22
|
+
['color-gray-400', '#959ba4'],
|
|
23
|
+
['color-gray-500', '#79818c'],
|
|
24
|
+
['color-gray-600', '#616871'],
|
|
25
|
+
['color-green-100', '#39b54a'],
|
|
26
|
+
['color-green-200', '#2ca53a'],
|
|
27
|
+
['color-green-300', '#168a21'],
|
|
28
|
+
['color-light-blue-100', '#ecf1f7'],
|
|
29
|
+
['color-light-blue-200', '#e4ebf3'],
|
|
30
|
+
['color-light-blue-300', '#dde4ed'],
|
|
31
|
+
['color-red-100', '#e01f19'],
|
|
32
|
+
['color-red-200', '#d3120e'],
|
|
33
|
+
['color-red-300', '#c40b08'],
|
|
34
|
+
['color-yellow-100', '#FFDD2C'],
|
|
35
|
+
['color-yellow-200', '#FCC521'],
|
|
36
|
+
['color-yellow-300', '#FAB618'],
|
|
37
|
+
['transparent', 'transparent'],
|
|
38
|
+
]);
|
|
39
|
+
/**
|
|
40
|
+
* @deprecated: drop in v5.0
|
|
41
|
+
*/
|
|
42
|
+
export const TuiColorSelectorMode = {
|
|
43
|
+
SolidColor: 0,
|
|
44
|
+
Gradient: 1,
|
|
45
|
+
};
|
|
46
|
+
/**
|
|
47
|
+
* @deprecated: drop in v5.0
|
|
48
|
+
*/
|
|
49
|
+
export const TUI_COLOR_SELECTOR_DEFAULT_OPTIONS = {
|
|
50
|
+
selectorMode: true,
|
|
51
|
+
mode: TuiColorSelectorMode.SolidColor,
|
|
52
|
+
color: [0, 0, 0, 1],
|
|
53
|
+
colors: new Map(),
|
|
54
|
+
gradient: {
|
|
55
|
+
icons: {
|
|
56
|
+
'to top right': '@tui.move-up-right',
|
|
57
|
+
'to right': '@tui.move-right',
|
|
58
|
+
'to bottom right': '@tui.move-down-right',
|
|
59
|
+
'to bottom': '@tui.move-down',
|
|
60
|
+
'to bottom left': '@tui.move-down-left',
|
|
61
|
+
'to left': '@tui.move-left',
|
|
62
|
+
'to top left': '@tui.move-up-left',
|
|
63
|
+
'to top': '@tui.move-up',
|
|
64
|
+
},
|
|
65
|
+
steps: [
|
|
66
|
+
[0, [0, 0, 0, 1]],
|
|
67
|
+
[1, [255, 255, 255, 1]],
|
|
68
|
+
],
|
|
69
|
+
stop: 0,
|
|
70
|
+
direction: 'to bottom',
|
|
71
|
+
emptyStop: [0, 0, 0, 0],
|
|
72
|
+
buttons: [
|
|
73
|
+
'to top right',
|
|
74
|
+
'to right',
|
|
75
|
+
'to bottom right',
|
|
76
|
+
'to bottom',
|
|
77
|
+
'to bottom left',
|
|
78
|
+
'to left',
|
|
79
|
+
'to top left',
|
|
80
|
+
'to top',
|
|
81
|
+
],
|
|
82
|
+
},
|
|
83
|
+
};
|
|
84
|
+
/**
|
|
85
|
+
* @deprecated: drop in v5.0
|
|
86
|
+
*/
|
|
87
|
+
export const TUI_COLOR_SELECTOR_OPTIONS = tuiCreateToken(TUI_COLOR_SELECTOR_DEFAULT_OPTIONS);
|
|
88
|
+
/**
|
|
89
|
+
* @deprecated: drop in v5.0
|
|
90
|
+
*/
|
|
91
|
+
export function tuiColorSelectorOptionsProvider(options) {
|
|
92
|
+
return tuiProvideOptions(TUI_COLOR_SELECTOR_OPTIONS, options, TUI_COLOR_SELECTOR_DEFAULT_OPTIONS);
|
|
93
|
+
}
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-selector.options.js","sourceRoot":"","sources":["../../../../../projects/legacy/components/color-selector/color-selector.options.ts"],"names":[],"mappings":"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","sourcesContent":["import type {Provider} from '@angular/core';\nimport {InjectionToken} from '@angular/core';\nimport type {TuiGradientDirection} from '@taiga-ui/cdk/utils/color';\nimport {tuiCreateToken, tuiProvideOptions} from '@taiga-ui/cdk/utils/miscellaneous';\n\n/**\n * @deprecated: drop in v5.0\n */\nexport const TUI_COLOR_SELECTOR_MODE_NAMES = new InjectionToken<[string, string]>(\n    '[TUI_COLOR_SELECTOR_MODE_NAMES]',\n    {\n        factory: () => ['Solid color', 'Gradient'],\n    },\n);\n\n/**\n * @deprecated: drop in v5.0\n */\nexport const TUI_DEFAULT_INPUT_COLORS = new Map([\n    ['color-black-100', '#909090'],\n    ['color-black-200', '#666666'],\n    ['color-black-300', '#333333'],\n    ['color-blue-100', '#1771e6'],\n    ['color-blue-200', '#1464cc'],\n    ['color-blue-300', '#0953b3'],\n    ['color-gray-100', '#f5f5f6'],\n    ['color-gray-200', '#e7e8ea'],\n    ['color-gray-300', '#cbcfd3'],\n    ['color-gray-400', '#959ba4'],\n    ['color-gray-500', '#79818c'],\n    ['color-gray-600', '#616871'],\n    ['color-green-100', '#39b54a'],\n    ['color-green-200', '#2ca53a'],\n    ['color-green-300', '#168a21'],\n    ['color-light-blue-100', '#ecf1f7'],\n    ['color-light-blue-200', '#e4ebf3'],\n    ['color-light-blue-300', '#dde4ed'],\n    ['color-red-100', '#e01f19'],\n    ['color-red-200', '#d3120e'],\n    ['color-red-300', '#c40b08'],\n    ['color-yellow-100', '#FFDD2C'],\n    ['color-yellow-200', '#FCC521'],\n    ['color-yellow-300', '#FAB618'],\n    ['transparent', 'transparent'],\n]);\n\n/**\n * @deprecated: drop in v5.0\n */\nexport const TuiColorSelectorMode = {\n    SolidColor: 0,\n    Gradient: 1,\n} as const;\n\n/**\n * @deprecated: drop in v5.0\n */\nexport interface TuiColorSelectorOptions {\n    readonly mode: (typeof TuiColorSelectorMode)[keyof typeof TuiColorSelectorMode];\n    readonly selectorMode: boolean;\n    readonly color: [number, number, number, number];\n    readonly colors: ReadonlyMap<string, string>;\n    readonly gradient: {\n        readonly icons: Record<TuiGradientDirection, string>;\n        readonly steps: ReadonlyArray<[number, [number, number, number, number]]>;\n        readonly stop: number;\n        readonly direction: TuiGradientDirection;\n        readonly emptyStop: [number, number, number, number];\n        readonly buttons: readonly TuiGradientDirection[];\n    };\n}\n\n/**\n * @deprecated: drop in v5.0\n */\nexport const TUI_COLOR_SELECTOR_DEFAULT_OPTIONS: TuiColorSelectorOptions = {\n    selectorMode: true,\n    mode: TuiColorSelectorMode.SolidColor,\n    color: [0, 0, 0, 1],\n    colors: new Map<string, string>(),\n    gradient: {\n        icons: {\n            'to top right': '@tui.move-up-right',\n            'to right': '@tui.move-right',\n            'to bottom right': '@tui.move-down-right',\n            'to bottom': '@tui.move-down',\n            'to bottom left': '@tui.move-down-left',\n            'to left': '@tui.move-left',\n            'to top left': '@tui.move-up-left',\n            'to top': '@tui.move-up',\n        },\n        steps: [\n            [0, [0, 0, 0, 1]],\n            [1, [255, 255, 255, 1]],\n        ],\n        stop: 0,\n        direction: 'to bottom',\n        emptyStop: [0, 0, 0, 0],\n        buttons: [\n            'to top right',\n            'to right',\n            'to bottom right',\n            'to bottom',\n            'to bottom left',\n            'to left',\n            'to top left',\n            'to top',\n        ],\n    },\n};\n\n/**\n * @deprecated: drop in v5.0\n */\nexport const TUI_COLOR_SELECTOR_OPTIONS = tuiCreateToken(\n    TUI_COLOR_SELECTOR_DEFAULT_OPTIONS,\n);\n\n/**\n * @deprecated: drop in v5.0\n */\nexport function tuiColorSelectorOptionsProvider(\n    options: Partial<TuiColorSelectorOptions>,\n): Provider {\n    return tuiProvideOptions(\n        TUI_COLOR_SELECTOR_OPTIONS,\n        options,\n        TUI_COLOR_SELECTOR_DEFAULT_OPTIONS,\n    );\n}\n"]}
|
|
@@ -4,6 +4,7 @@ export * from './color-picker/color-picker.component';
|
|
|
4
4
|
export * from './color-picker/color-picker.module';
|
|
5
5
|
export * from './color-selector.component';
|
|
6
6
|
export * from './color-selector.module';
|
|
7
|
+
export * from './color-selector.options';
|
|
7
8
|
export * from './flat-picker/flat-picker.component';
|
|
8
9
|
export * from './flat-picker/flat-picker.module';
|
|
9
10
|
export * from './linear-multi-picker/linear-multi-picker.component';
|
|
@@ -13,4 +14,4 @@ export * from './linear-picker/linear-picker.module';
|
|
|
13
14
|
export * from './palette/palette.component';
|
|
14
15
|
export * from './palette/palette.module';
|
|
15
16
|
export * from './services/picker.service';
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9sZWdhY3kvY29tcG9uZW50cy9jb2xvci1zZWxlY3Rvci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb2xvci1lZGl0L2NvbG9yLWVkaXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29sb3ItZWRpdC9jb2xvci1lZGl0Lm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbG9yLXBpY2tlci9jb2xvci1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29sb3ItcGlja2VyL2NvbG9yLXBpY2tlci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2xvci1zZWxlY3Rvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2xvci1zZWxlY3Rvci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2xvci1zZWxlY3Rvci5vcHRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vZmxhdC1waWNrZXIvZmxhdC1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZmxhdC1waWNrZXIvZmxhdC1waWNrZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGluZWFyLW11bHRpLXBpY2tlci9saW5lYXItbXVsdGktcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpbmVhci1tdWx0aS1waWNrZXIvbGluZWFyLW11bHRpLXBpY2tlci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saW5lYXItcGlja2VyL2xpbmVhci1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGluZWFyLXBpY2tlci9saW5lYXItcGlja2VyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3BhbGV0dGUvcGFsZXR0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9wYWxldHRlL3BhbGV0dGUubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vc2VydmljZXMvcGlja2VyLnNlcnZpY2UnO1xuIl19
|