@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.
Files changed (38) hide show
  1. package/components/color-selector/color-selector.component.d.ts +4 -10
  2. package/components/color-selector/color-selector.options.d.ts +47 -0
  3. package/components/color-selector/index.d.ts +1 -0
  4. package/components/input-time/input-time.component.d.ts +5 -1
  5. package/esm2022/components/color-selector/color-selector.component.mjs +31 -89
  6. package/esm2022/components/color-selector/color-selector.options.mjs +94 -0
  7. package/esm2022/components/color-selector/index.mjs +2 -1
  8. package/esm2022/components/input-number/input-number.component.mjs +2 -2
  9. package/esm2022/components/input-password/input-password.component.mjs +3 -3
  10. package/esm2022/components/input-tag/input-tag.component.mjs +3 -3
  11. package/esm2022/components/input-time/input-time.component.mjs +10 -2
  12. package/esm2022/components/svg/svg.component.mjs +2 -2
  13. package/esm2022/index.mjs +2 -1
  14. package/esm2022/services/index.mjs +2 -0
  15. package/esm2022/services/static-request.service.mjs +36 -0
  16. package/esm2022/services/taiga-ui-legacy-services.mjs +5 -0
  17. package/fesm2022/taiga-ui-legacy-components-color-selector.mjs +123 -90
  18. package/fesm2022/taiga-ui-legacy-components-color-selector.mjs.map +1 -1
  19. package/fesm2022/taiga-ui-legacy-components-input-number.mjs +2 -2
  20. package/fesm2022/taiga-ui-legacy-components-input-number.mjs.map +1 -1
  21. package/fesm2022/taiga-ui-legacy-components-input-password.mjs +2 -2
  22. package/fesm2022/taiga-ui-legacy-components-input-password.mjs.map +1 -1
  23. package/fesm2022/taiga-ui-legacy-components-input-tag.mjs +2 -2
  24. package/fesm2022/taiga-ui-legacy-components-input-tag.mjs.map +1 -1
  25. package/fesm2022/taiga-ui-legacy-components-input-time.mjs +9 -1
  26. package/fesm2022/taiga-ui-legacy-components-input-time.mjs.map +1 -1
  27. package/fesm2022/taiga-ui-legacy-components-svg.mjs +1 -1
  28. package/fesm2022/taiga-ui-legacy-components-svg.mjs.map +1 -1
  29. package/fesm2022/taiga-ui-legacy-services.mjs +42 -0
  30. package/fesm2022/taiga-ui-legacy-services.mjs.map +1 -0
  31. package/fesm2022/taiga-ui-legacy.mjs +1 -0
  32. package/fesm2022/taiga-ui-legacy.mjs.map +1 -1
  33. package/index.d.ts +1 -0
  34. package/package.json +7 -1
  35. package/services/index.d.ts +1 -0
  36. package/services/static-request.service.d.ts +11 -0
  37. package/styles/mixins/mixins.less +2 -2
  38. package/utils/icons-path-factory.d.ts +1 -1
@@ -1,23 +1,17 @@
1
- import { EventEmitter, InjectionToken } from '@angular/core';
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, InjectionToken, Input, Output, } from '@angular/core';
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.stops = new Map(DEFAULT_STEPS);
76
- this.currentStop = 0;
77
- this.direction = 'to bottom';
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.colors = new Map();
30
+ this.open = false;
31
+ this.colors = this.selectorOptions.colors;
80
32
  this.colorChange = new EventEmitter();
81
- this.color = [0, 0, 0, 1];
33
+ this.color = this.selectorOptions.color;
82
34
  this.modes = inject(TUI_COLOR_SELECTOR_MODE_NAMES);
83
- this.currentMode = this.modes[0];
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
- this.parse(color);
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[1];
62
+ return this.currentMode === this.modes[TuiColorSelectorMode.Gradient];
112
63
  }
113
64
  getIcon(direction) {
114
- return ICONS[direction];
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.updateColor(mode === this.modes[0]
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) || EMPTY_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 = 0;
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
- : DEFAULT_STEPS);
165
+ : this.selectorOptions.gradient.steps);
223
166
  }
224
167
  parseColor(color) {
225
- this.currentMode = this.modes[0];
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 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", 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}.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}.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 }); }
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 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", 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}.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}.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"] }]
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9sZWdhY3kvY29tcG9uZW50cy9jb2xvci1zZWxlY3Rvci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxxREFBcUQsQ0FBQztBQUNwRSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyxzQ0FBc0MsQ0FBQztBQUNyRCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29sb3ItZWRpdC9jb2xvci1lZGl0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbG9yLWVkaXQvY29sb3ItZWRpdC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2xvci1waWNrZXIvY29sb3ItcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbG9yLXBpY2tlci9jb2xvci1waWNrZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vY29sb3Itc2VsZWN0b3IuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29sb3Itc2VsZWN0b3IubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vZmxhdC1waWNrZXIvZmxhdC1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZmxhdC1waWNrZXIvZmxhdC1waWNrZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGluZWFyLW11bHRpLXBpY2tlci9saW5lYXItbXVsdGktcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpbmVhci1tdWx0aS1waWNrZXIvbGluZWFyLW11bHRpLXBpY2tlci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saW5lYXItcGlja2VyL2xpbmVhci1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGluZWFyLXBpY2tlci9saW5lYXItcGlja2VyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3BhbGV0dGUvcGFsZXR0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9wYWxldHRlL3BhbGV0dGUubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vc2VydmljZXMvcGlja2VyLnNlcnZpY2UnO1xuIl19
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9sZWdhY3kvY29tcG9uZW50cy9jb2xvci1zZWxlY3Rvci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb2xvci1lZGl0L2NvbG9yLWVkaXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29sb3ItZWRpdC9jb2xvci1lZGl0Lm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbG9yLXBpY2tlci9jb2xvci1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29sb3ItcGlja2VyL2NvbG9yLXBpY2tlci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2xvci1zZWxlY3Rvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2xvci1zZWxlY3Rvci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9jb2xvci1zZWxlY3Rvci5vcHRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vZmxhdC1waWNrZXIvZmxhdC1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZmxhdC1waWNrZXIvZmxhdC1waWNrZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGluZWFyLW11bHRpLXBpY2tlci9saW5lYXItbXVsdGktcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpbmVhci1tdWx0aS1waWNrZXIvbGluZWFyLW11bHRpLXBpY2tlci5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saW5lYXItcGlja2VyL2xpbmVhci1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGluZWFyLXBpY2tlci9saW5lYXItcGlja2VyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3BhbGV0dGUvcGFsZXR0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9wYWxldHRlL3BhbGV0dGUubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vc2VydmljZXMvcGlja2VyLnNlcnZpY2UnO1xuIl19