ngx-color 7.3.0 → 7.3.1

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 (219) hide show
  1. package/alpha/package.json +6 -22
  2. package/block/block-swatches.component.d.ts +10 -8
  3. package/block/package.json +6 -22
  4. package/chrome/package.json +6 -22
  5. package/circle/package.json +9 -22
  6. package/compact/package.json +6 -22
  7. package/esm2020/alpha/alpha-picker.component.mjs +116 -0
  8. package/esm2020/alpha/ngx-color-alpha.mjs +5 -0
  9. package/esm2020/alpha/public_api.mjs +2 -0
  10. package/esm2020/alpha.component.mjs +1 -1
  11. package/{block/esm2020 → esm2020/block}/block-swatches.component.mjs +2 -4
  12. package/{block/esm2020 → esm2020/block}/block.component.mjs +1 -1
  13. package/esm2020/block/ngx-color-block.mjs +5 -0
  14. package/esm2020/block/public_api.mjs +3 -0
  15. package/esm2020/checkboard.component.mjs +1 -1
  16. package/esm2020/chrome/chrome-fields.component.mjs +356 -0
  17. package/{chrome/esm2020 → esm2020/chrome}/chrome.component.mjs +1 -1
  18. package/esm2020/chrome/ngx-color-chrome.mjs +5 -0
  19. package/esm2020/chrome/public_api.mjs +3 -0
  20. package/esm2020/circle/circle-swatch.component.mjs +85 -0
  21. package/esm2020/circle/circle.component.mjs +148 -0
  22. package/esm2020/circle/ngx-color-circle.mjs +5 -0
  23. package/esm2020/circle/public_api.mjs +3 -0
  24. package/esm2020/color-wrap.component.mjs +1 -1
  25. package/esm2020/compact/compact-color.component.mjs +91 -0
  26. package/esm2020/compact/compact-fields.component.mjs +186 -0
  27. package/{compact/esm2020 → esm2020/compact}/compact.component.mjs +1 -1
  28. package/esm2020/compact/ngx-color-compact.mjs +5 -0
  29. package/esm2020/compact/public_api.mjs +4 -0
  30. package/esm2020/coordinates.directive.mjs +1 -1
  31. package/esm2020/editable-input.component.mjs +1 -1
  32. package/{github/esm2020 → esm2020/github}/github-swatch.component.mjs +1 -1
  33. package/{github/esm2020 → esm2020/github}/github.component.mjs +1 -1
  34. package/esm2020/github/ngx-color-github.mjs +5 -0
  35. package/esm2020/github/public_api.mjs +3 -0
  36. package/esm2020/helpers/checkboard.mjs +1 -1
  37. package/esm2020/helpers/color.interfaces.mjs +1 -1
  38. package/esm2020/helpers/color.mjs +1 -1
  39. package/esm2020/hue/hue-picker.component.mjs +113 -0
  40. package/esm2020/hue/ngx-color-hue.mjs +5 -0
  41. package/esm2020/hue/public_api.mjs +2 -0
  42. package/esm2020/hue.component.mjs +1 -1
  43. package/esm2020/material/material.component.mjs +211 -0
  44. package/esm2020/material/ngx-color-material.mjs +5 -0
  45. package/esm2020/material/public_api.mjs +2 -0
  46. package/esm2020/ngx-color.mjs +1 -1
  47. package/esm2020/photoshop/ngx-color-photoshop.mjs +5 -0
  48. package/{photoshop/esm2020 → esm2020/photoshop}/photoshop-button.component.mjs +1 -1
  49. package/esm2020/photoshop/photoshop-fields.component.mjs +241 -0
  50. package/{photoshop/esm2020 → esm2020/photoshop}/photoshop-previews.component.mjs +1 -1
  51. package/{photoshop/esm2020 → esm2020/photoshop}/photoshop.component.mjs +1 -1
  52. package/esm2020/photoshop/public_api.mjs +5 -0
  53. package/esm2020/public_api.mjs +1 -1
  54. package/esm2020/raised.component.mjs +1 -1
  55. package/esm2020/saturation.component.mjs +1 -1
  56. package/esm2020/shade/ngx-color-shade.mjs +5 -0
  57. package/esm2020/shade/public_api.mjs +2 -0
  58. package/esm2020/shade/shade-picker.component.mjs +105 -0
  59. package/esm2020/shade.component.mjs +1 -1
  60. package/esm2020/sketch/ngx-color-sketch.mjs +5 -0
  61. package/esm2020/sketch/public_api.mjs +4 -0
  62. package/esm2020/sketch/sketch-fields.component.mjs +243 -0
  63. package/{sketch/esm2020 → esm2020/sketch}/sketch-preset-colors.component.mjs +1 -1
  64. package/{sketch/esm2020 → esm2020/sketch}/sketch.component.mjs +1 -1
  65. package/esm2020/slider/ngx-color-slider.mjs +5 -0
  66. package/esm2020/slider/public_api.mjs +4 -0
  67. package/esm2020/slider/slider-swatch.component.mjs +80 -0
  68. package/{slider/esm2020 → esm2020/slider}/slider-swatches.component.mjs +1 -1
  69. package/{slider/esm2020 → esm2020/slider}/slider.component.mjs +1 -1
  70. package/esm2020/swatch.component.mjs +1 -1
  71. package/esm2020/swatches/ngx-color-swatches.mjs +5 -0
  72. package/esm2020/swatches/public_api.mjs +4 -0
  73. package/esm2020/swatches/swatches-color.component.mjs +123 -0
  74. package/{swatches/esm2020 → esm2020/swatches}/swatches-group.component.mjs +1 -1
  75. package/esm2020/swatches/swatches.component.mjs +258 -0
  76. package/esm2020/twitter/ngx-color-twitter.mjs +5 -0
  77. package/esm2020/twitter/public_api.mjs +2 -0
  78. package/{twitter/esm2020 → esm2020/twitter}/twitter.component.mjs +1 -1
  79. package/{alpha/fesm2015 → fesm2015}/ngx-color-alpha.mjs +0 -0
  80. package/fesm2015/ngx-color-alpha.mjs.map +1 -0
  81. package/{block/fesm2015 → fesm2015}/ngx-color-block.mjs +1 -3
  82. package/fesm2015/ngx-color-block.mjs.map +1 -0
  83. package/{chrome/fesm2015 → fesm2015}/ngx-color-chrome.mjs +0 -0
  84. package/fesm2015/ngx-color-chrome.mjs.map +1 -0
  85. package/{circle/fesm2015 → fesm2015}/ngx-color-circle.mjs +0 -0
  86. package/fesm2015/ngx-color-circle.mjs.map +1 -0
  87. package/{compact/fesm2015 → fesm2015}/ngx-color-compact.mjs +0 -0
  88. package/fesm2015/ngx-color-compact.mjs.map +1 -0
  89. package/{github/fesm2015 → fesm2015}/ngx-color-github.mjs +0 -0
  90. package/fesm2015/ngx-color-github.mjs.map +1 -0
  91. package/{hue/fesm2015 → fesm2015}/ngx-color-hue.mjs +0 -0
  92. package/fesm2015/ngx-color-hue.mjs.map +1 -0
  93. package/{material/fesm2015 → fesm2015}/ngx-color-material.mjs +0 -0
  94. package/fesm2015/ngx-color-material.mjs.map +1 -0
  95. package/{photoshop/fesm2015 → fesm2015}/ngx-color-photoshop.mjs +0 -0
  96. package/fesm2015/ngx-color-photoshop.mjs.map +1 -0
  97. package/{shade/fesm2015 → fesm2015}/ngx-color-shade.mjs +0 -0
  98. package/fesm2015/ngx-color-shade.mjs.map +1 -0
  99. package/{sketch/fesm2015 → fesm2015}/ngx-color-sketch.mjs +0 -0
  100. package/fesm2015/ngx-color-sketch.mjs.map +1 -0
  101. package/{slider/fesm2015 → fesm2015}/ngx-color-slider.mjs +0 -0
  102. package/fesm2015/ngx-color-slider.mjs.map +1 -0
  103. package/{swatches/fesm2015 → fesm2015}/ngx-color-swatches.mjs +0 -0
  104. package/fesm2015/ngx-color-swatches.mjs.map +1 -0
  105. package/{twitter/fesm2015 → fesm2015}/ngx-color-twitter.mjs +0 -0
  106. package/fesm2015/ngx-color-twitter.mjs.map +1 -0
  107. package/fesm2015/ngx-color.mjs.map +1 -1
  108. package/{alpha/fesm2020 → fesm2020}/ngx-color-alpha.mjs +0 -0
  109. package/fesm2020/ngx-color-alpha.mjs.map +1 -0
  110. package/{block/fesm2020 → fesm2020}/ngx-color-block.mjs +1 -3
  111. package/fesm2020/ngx-color-block.mjs.map +1 -0
  112. package/{chrome/fesm2020 → fesm2020}/ngx-color-chrome.mjs +0 -0
  113. package/fesm2020/ngx-color-chrome.mjs.map +1 -0
  114. package/{circle/fesm2020 → fesm2020}/ngx-color-circle.mjs +0 -0
  115. package/fesm2020/ngx-color-circle.mjs.map +1 -0
  116. package/{compact/fesm2020 → fesm2020}/ngx-color-compact.mjs +0 -0
  117. package/fesm2020/ngx-color-compact.mjs.map +1 -0
  118. package/{github/fesm2020 → fesm2020}/ngx-color-github.mjs +0 -0
  119. package/fesm2020/ngx-color-github.mjs.map +1 -0
  120. package/{hue/fesm2020 → fesm2020}/ngx-color-hue.mjs +0 -0
  121. package/fesm2020/ngx-color-hue.mjs.map +1 -0
  122. package/{material/fesm2020 → fesm2020}/ngx-color-material.mjs +0 -0
  123. package/fesm2020/ngx-color-material.mjs.map +1 -0
  124. package/{photoshop/fesm2020 → fesm2020}/ngx-color-photoshop.mjs +0 -0
  125. package/fesm2020/ngx-color-photoshop.mjs.map +1 -0
  126. package/{shade/fesm2020 → fesm2020}/ngx-color-shade.mjs +0 -0
  127. package/fesm2020/ngx-color-shade.mjs.map +1 -0
  128. package/{sketch/fesm2020 → fesm2020}/ngx-color-sketch.mjs +0 -0
  129. package/fesm2020/ngx-color-sketch.mjs.map +1 -0
  130. package/{slider/fesm2020 → fesm2020}/ngx-color-slider.mjs +0 -0
  131. package/fesm2020/ngx-color-slider.mjs.map +1 -0
  132. package/{swatches/fesm2020 → fesm2020}/ngx-color-swatches.mjs +0 -0
  133. package/fesm2020/ngx-color-swatches.mjs.map +1 -0
  134. package/{twitter/fesm2020 → fesm2020}/ngx-color-twitter.mjs +0 -0
  135. package/fesm2020/ngx-color-twitter.mjs.map +1 -0
  136. package/fesm2020/ngx-color.mjs.map +1 -1
  137. package/github/package.json +6 -22
  138. package/helpers/checkboard.d.ts +2 -2
  139. package/hue/package.json +6 -22
  140. package/material/package.json +6 -22
  141. package/package.json +119 -8
  142. package/photoshop/package.json +6 -22
  143. package/shade/package.json +6 -22
  144. package/sketch/package.json +6 -22
  145. package/slider/package.json +6 -22
  146. package/swatches/package.json +9 -22
  147. package/twitter/package.json +6 -22
  148. package/LICENSE +0 -21
  149. package/README.md +0 -280
  150. package/alpha/esm2020/alpha-picker.component.mjs +0 -116
  151. package/alpha/esm2020/ngx-color-alpha.mjs +0 -5
  152. package/alpha/esm2020/public_api.mjs +0 -2
  153. package/alpha/fesm2015/ngx-color-alpha.mjs.map +0 -1
  154. package/alpha/fesm2020/ngx-color-alpha.mjs.map +0 -1
  155. package/block/esm2020/ngx-color-block.mjs +0 -5
  156. package/block/esm2020/public_api.mjs +0 -3
  157. package/block/fesm2015/ngx-color-block.mjs.map +0 -1
  158. package/block/fesm2020/ngx-color-block.mjs.map +0 -1
  159. package/chrome/esm2020/chrome-fields.component.mjs +0 -356
  160. package/chrome/esm2020/ngx-color-chrome.mjs +0 -5
  161. package/chrome/esm2020/public_api.mjs +0 -3
  162. package/chrome/fesm2015/ngx-color-chrome.mjs.map +0 -1
  163. package/chrome/fesm2020/ngx-color-chrome.mjs.map +0 -1
  164. package/circle/esm2020/circle-swatch.component.mjs +0 -85
  165. package/circle/esm2020/circle.component.mjs +0 -148
  166. package/circle/esm2020/ngx-color-circle.mjs +0 -5
  167. package/circle/esm2020/public_api.mjs +0 -3
  168. package/circle/fesm2015/ngx-color-circle.mjs.map +0 -1
  169. package/circle/fesm2020/ngx-color-circle.mjs.map +0 -1
  170. package/compact/esm2020/compact-color.component.mjs +0 -91
  171. package/compact/esm2020/compact-fields.component.mjs +0 -186
  172. package/compact/esm2020/ngx-color-compact.mjs +0 -5
  173. package/compact/esm2020/public_api.mjs +0 -4
  174. package/compact/fesm2015/ngx-color-compact.mjs.map +0 -1
  175. package/compact/fesm2020/ngx-color-compact.mjs.map +0 -1
  176. package/github/esm2020/ngx-color-github.mjs +0 -5
  177. package/github/esm2020/public_api.mjs +0 -3
  178. package/github/fesm2015/ngx-color-github.mjs.map +0 -1
  179. package/github/fesm2020/ngx-color-github.mjs.map +0 -1
  180. package/hue/esm2020/hue-picker.component.mjs +0 -113
  181. package/hue/esm2020/ngx-color-hue.mjs +0 -5
  182. package/hue/esm2020/public_api.mjs +0 -2
  183. package/hue/fesm2015/ngx-color-hue.mjs.map +0 -1
  184. package/hue/fesm2020/ngx-color-hue.mjs.map +0 -1
  185. package/material/esm2020/material.component.mjs +0 -211
  186. package/material/esm2020/ngx-color-material.mjs +0 -5
  187. package/material/esm2020/public_api.mjs +0 -2
  188. package/material/fesm2015/ngx-color-material.mjs.map +0 -1
  189. package/material/fesm2020/ngx-color-material.mjs.map +0 -1
  190. package/photoshop/esm2020/ngx-color-photoshop.mjs +0 -5
  191. package/photoshop/esm2020/photoshop-fields.component.mjs +0 -241
  192. package/photoshop/esm2020/public_api.mjs +0 -5
  193. package/photoshop/fesm2015/ngx-color-photoshop.mjs.map +0 -1
  194. package/photoshop/fesm2020/ngx-color-photoshop.mjs.map +0 -1
  195. package/shade/esm2020/ngx-color-shade.mjs +0 -5
  196. package/shade/esm2020/public_api.mjs +0 -2
  197. package/shade/esm2020/shade-picker.component.mjs +0 -105
  198. package/shade/fesm2015/ngx-color-shade.mjs.map +0 -1
  199. package/shade/fesm2020/ngx-color-shade.mjs.map +0 -1
  200. package/sketch/esm2020/ngx-color-sketch.mjs +0 -5
  201. package/sketch/esm2020/public_api.mjs +0 -4
  202. package/sketch/esm2020/sketch-fields.component.mjs +0 -243
  203. package/sketch/fesm2015/ngx-color-sketch.mjs.map +0 -1
  204. package/sketch/fesm2020/ngx-color-sketch.mjs.map +0 -1
  205. package/slider/esm2020/ngx-color-slider.mjs +0 -5
  206. package/slider/esm2020/public_api.mjs +0 -4
  207. package/slider/esm2020/slider-swatch.component.mjs +0 -80
  208. package/slider/fesm2015/ngx-color-slider.mjs.map +0 -1
  209. package/slider/fesm2020/ngx-color-slider.mjs.map +0 -1
  210. package/swatches/esm2020/ngx-color-swatches.mjs +0 -5
  211. package/swatches/esm2020/public_api.mjs +0 -4
  212. package/swatches/esm2020/swatches-color.component.mjs +0 -123
  213. package/swatches/esm2020/swatches.component.mjs +0 -258
  214. package/swatches/fesm2015/ngx-color-swatches.mjs.map +0 -1
  215. package/swatches/fesm2020/ngx-color-swatches.mjs.map +0 -1
  216. package/twitter/esm2020/ngx-color-twitter.mjs +0 -5
  217. package/twitter/esm2020/public_api.mjs +0 -2
  218. package/twitter/fesm2015/ngx-color-twitter.mjs.map +0 -1
  219. package/twitter/fesm2020/ngx-color-twitter.mjs.map +0 -1
@@ -0,0 +1,356 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
2
+ import { isValidHex } from 'ngx-color';
3
+ import { TinyColor } from '@ctrl/tinycolor';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "ngx-color";
6
+ import * as i2 from "@angular/common";
7
+ export class ChromeFieldsComponent {
8
+ constructor() {
9
+ this.onChange = new EventEmitter();
10
+ this.view = '';
11
+ this.input = {
12
+ fontSize: '11px',
13
+ color: '#333',
14
+ width: '100%',
15
+ borderRadius: '2px',
16
+ border: 'none',
17
+ boxShadow: 'inset 0 0 0 1px #dadada',
18
+ height: '21px',
19
+ 'text-align': 'center',
20
+ };
21
+ this.label = {
22
+ 'text-transform': 'uppercase',
23
+ fontSize: '11px',
24
+ 'line-height': '11px',
25
+ color: '#969696',
26
+ 'text-align': 'center',
27
+ display: 'block',
28
+ marginTop: '12px',
29
+ };
30
+ }
31
+ ngOnInit() {
32
+ if (this.hsl.a === 1 && this.view !== 'hex') {
33
+ this.view = 'hex';
34
+ }
35
+ else if (this.view !== 'rgb' && this.view !== 'hsl') {
36
+ this.view = 'rgb';
37
+ }
38
+ }
39
+ toggleViews() {
40
+ if (this.view === 'hex') {
41
+ this.view = 'rgb';
42
+ }
43
+ else if (this.view === 'rgb') {
44
+ this.view = 'hsl';
45
+ }
46
+ else if (this.view === 'hsl') {
47
+ if (this.hsl.a === 1) {
48
+ this.view = 'hex';
49
+ }
50
+ else {
51
+ this.view = 'rgb';
52
+ }
53
+ }
54
+ }
55
+ round(value) {
56
+ return Math.round(value);
57
+ }
58
+ handleChange({ data, $event }) {
59
+ if (data.hex) {
60
+ if (isValidHex(data.hex)) {
61
+ const color = new TinyColor(data.hex);
62
+ this.onChange.emit({
63
+ data: {
64
+ hex: this.disableAlpha ? color.toHex() : color.toHex8(),
65
+ source: 'hex',
66
+ },
67
+ $event,
68
+ });
69
+ }
70
+ }
71
+ else if (data.r || data.g || data.b) {
72
+ this.onChange.emit({
73
+ data: {
74
+ r: data.r || this.rgb.r,
75
+ g: data.g || this.rgb.g,
76
+ b: data.b || this.rgb.b,
77
+ source: 'rgb',
78
+ },
79
+ $event,
80
+ });
81
+ }
82
+ else if (data.a) {
83
+ if (data.a < 0) {
84
+ data.a = 0;
85
+ }
86
+ else if (data.a > 1) {
87
+ data.a = 1;
88
+ }
89
+ if (this.disableAlpha) {
90
+ data.a = 1;
91
+ }
92
+ this.onChange.emit({
93
+ data: {
94
+ h: this.hsl.h,
95
+ s: this.hsl.s,
96
+ l: this.hsl.l,
97
+ a: Math.round(data.a * 100) / 100,
98
+ source: 'rgb',
99
+ },
100
+ $event,
101
+ });
102
+ }
103
+ else if (data.h || data.s || data.l) {
104
+ const s = data.s && data.s.replace('%', '');
105
+ const l = data.l && data.l.replace('%', '');
106
+ this.onChange.emit({
107
+ data: {
108
+ h: data.h || this.hsl.h,
109
+ s: Number(s || this.hsl.s),
110
+ l: Number(l || this.hsl.l),
111
+ source: 'hsl',
112
+ },
113
+ $event,
114
+ });
115
+ }
116
+ }
117
+ }
118
+ ChromeFieldsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: ChromeFieldsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
119
+ ChromeFieldsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.0", type: ChromeFieldsComponent, selector: "color-chrome-fields", inputs: { disableAlpha: "disableAlpha", hsl: "hsl", rgb: "rgb", hex: "hex" }, outputs: { onChange: "onChange" }, ngImport: i0, template: `
120
+ <div class="chrome-wrap">
121
+ <div class="chrome-fields">
122
+ <ng-template [ngIf]="view === 'hex'">
123
+ <div class="chrome-field">
124
+ <color-editable-input
125
+ [style]="{ input: input, label: label }"
126
+ label="hex" [value]="hex"
127
+ (onChange)="handleChange($event)"
128
+ ></color-editable-input>
129
+ </div>
130
+ </ng-template>
131
+ <ng-template [ngIf]="view === 'rgb'">
132
+ <div class="chrome-field">
133
+ <color-editable-input
134
+ [style]="{ input: input, label: label }"
135
+ label="r" [value]="rgb.r"
136
+ (onChange)="handleChange($event)"
137
+ ></color-editable-input>
138
+ </div>
139
+ <div class="chrome-field">
140
+ <color-editable-input
141
+ [style]="{ input: input, label: label }"
142
+ label="g" [value]="rgb.g"
143
+ (onChange)="handleChange($event)"
144
+ ></color-editable-input>
145
+ </div>
146
+ <div class="chrome-field">
147
+ <color-editable-input
148
+ [style]="{ input: input, label: label }"
149
+ label="b" [value]="rgb.b"
150
+ (onChange)="handleChange($event)"
151
+ ></color-editable-input>
152
+ </div>
153
+ <div class="chrome-field">
154
+ <color-editable-input *ngIf="!disableAlpha"
155
+ [style]="{ input: input, label: label }"
156
+ label="a" [value]="rgb.a"
157
+ [arrowOffset]="0.01"
158
+ (onChange)="handleChange($event)"
159
+ ></color-editable-input>
160
+ </div>
161
+ </ng-template>
162
+ <ng-template [ngIf]="view === 'hsl'">
163
+ <div class="chrome-field">
164
+ <color-editable-input
165
+ [style]="{ input: input, label: label }"
166
+ label="h"
167
+ [value]="round(hsl.h)"
168
+ (onChange)="handleChange($event)"
169
+ ></color-editable-input>
170
+ </div>
171
+ <div class="chrome-field">
172
+ <color-editable-input
173
+ [style]="{ input: input, label: label }"
174
+ label="s" [value]="round(hsl.s * 100) + '%'"
175
+ (onChange)="handleChange($event)"
176
+ ></color-editable-input>
177
+ </div>
178
+ <div class="chrome-field">
179
+ <color-editable-input
180
+ [style]="{ input: input, label: label }"
181
+ label="l" [value]="round(hsl.l * 100) + '%'"
182
+ (onChange)="handleChange($event)"
183
+ ></color-editable-input>
184
+ </div>
185
+ <div class="chrome-field">
186
+ <color-editable-input *ngIf="!disableAlpha"
187
+ [style]="{ input: input, label: label }"
188
+ label="a" [value]="hsl.a"
189
+ [arrowOffset]="0.01"
190
+ (onChange)="handleChange($event)"
191
+ ></color-editable-input>
192
+ </div>
193
+ </ng-template>
194
+ </div>
195
+
196
+ <div class="chrome-toggle">
197
+ <div class="chrome-icon" (click)="toggleViews()" #icon>
198
+ <svg class="chrome-toggle-svg" viewBox="0 0 24 24">
199
+ <path #iconUp fill="#333"
200
+ d="M12,5.83L15.17,9L16.58,7.59L12,3L7.41,7.59L8.83,9L12,5.83Z"
201
+ />
202
+ <path #iconDown fill="#333"
203
+ d="M12,18.17L8.83,15L7.42,16.41L12,21L16.59,16.41L15.17,15Z"
204
+ />
205
+ </svg>
206
+ </div>
207
+ </div>
208
+ </div>
209
+ `, isInline: true, styles: [".chrome-wrap{padding-top:16px;display:flex}.chrome-fields{flex:1;display:flex;margin-left:-6px}.chrome-field{padding-left:6px;width:100%}.chrome-toggle{width:32px;text-align:right;position:relative}.chrome-icon{margin-right:-4px;margin-top:12px;cursor:pointer;position:relative}.chrome-toggle-svg{width:24px;height:24px;border:1px transparent solid;border-radius:5px}.chrome-toggle-svg:hover{background:#eee}\n"], components: [{ type: i1.EditableInputComponent, selector: "color-editable-input", inputs: ["style", "label", "value", "arrowOffset", "dragLabel", "dragMax", "placeholder"], outputs: ["onChange"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
210
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: ChromeFieldsComponent, decorators: [{
211
+ type: Component,
212
+ args: [{
213
+ selector: 'color-chrome-fields',
214
+ template: `
215
+ <div class="chrome-wrap">
216
+ <div class="chrome-fields">
217
+ <ng-template [ngIf]="view === 'hex'">
218
+ <div class="chrome-field">
219
+ <color-editable-input
220
+ [style]="{ input: input, label: label }"
221
+ label="hex" [value]="hex"
222
+ (onChange)="handleChange($event)"
223
+ ></color-editable-input>
224
+ </div>
225
+ </ng-template>
226
+ <ng-template [ngIf]="view === 'rgb'">
227
+ <div class="chrome-field">
228
+ <color-editable-input
229
+ [style]="{ input: input, label: label }"
230
+ label="r" [value]="rgb.r"
231
+ (onChange)="handleChange($event)"
232
+ ></color-editable-input>
233
+ </div>
234
+ <div class="chrome-field">
235
+ <color-editable-input
236
+ [style]="{ input: input, label: label }"
237
+ label="g" [value]="rgb.g"
238
+ (onChange)="handleChange($event)"
239
+ ></color-editable-input>
240
+ </div>
241
+ <div class="chrome-field">
242
+ <color-editable-input
243
+ [style]="{ input: input, label: label }"
244
+ label="b" [value]="rgb.b"
245
+ (onChange)="handleChange($event)"
246
+ ></color-editable-input>
247
+ </div>
248
+ <div class="chrome-field">
249
+ <color-editable-input *ngIf="!disableAlpha"
250
+ [style]="{ input: input, label: label }"
251
+ label="a" [value]="rgb.a"
252
+ [arrowOffset]="0.01"
253
+ (onChange)="handleChange($event)"
254
+ ></color-editable-input>
255
+ </div>
256
+ </ng-template>
257
+ <ng-template [ngIf]="view === 'hsl'">
258
+ <div class="chrome-field">
259
+ <color-editable-input
260
+ [style]="{ input: input, label: label }"
261
+ label="h"
262
+ [value]="round(hsl.h)"
263
+ (onChange)="handleChange($event)"
264
+ ></color-editable-input>
265
+ </div>
266
+ <div class="chrome-field">
267
+ <color-editable-input
268
+ [style]="{ input: input, label: label }"
269
+ label="s" [value]="round(hsl.s * 100) + '%'"
270
+ (onChange)="handleChange($event)"
271
+ ></color-editable-input>
272
+ </div>
273
+ <div class="chrome-field">
274
+ <color-editable-input
275
+ [style]="{ input: input, label: label }"
276
+ label="l" [value]="round(hsl.l * 100) + '%'"
277
+ (onChange)="handleChange($event)"
278
+ ></color-editable-input>
279
+ </div>
280
+ <div class="chrome-field">
281
+ <color-editable-input *ngIf="!disableAlpha"
282
+ [style]="{ input: input, label: label }"
283
+ label="a" [value]="hsl.a"
284
+ [arrowOffset]="0.01"
285
+ (onChange)="handleChange($event)"
286
+ ></color-editable-input>
287
+ </div>
288
+ </ng-template>
289
+ </div>
290
+
291
+ <div class="chrome-toggle">
292
+ <div class="chrome-icon" (click)="toggleViews()" #icon>
293
+ <svg class="chrome-toggle-svg" viewBox="0 0 24 24">
294
+ <path #iconUp fill="#333"
295
+ d="M12,5.83L15.17,9L16.58,7.59L12,3L7.41,7.59L8.83,9L12,5.83Z"
296
+ />
297
+ <path #iconDown fill="#333"
298
+ d="M12,18.17L8.83,15L7.42,16.41L12,21L16.59,16.41L15.17,15Z"
299
+ />
300
+ </svg>
301
+ </div>
302
+ </div>
303
+ </div>
304
+ `,
305
+ styles: [
306
+ `
307
+ .chrome-wrap {
308
+ padding-top: 16px;
309
+ display: flex;
310
+ }
311
+ .chrome-fields {
312
+ flex: 1;
313
+ display: flex;
314
+ margin-left: -6px;
315
+ }
316
+ .chrome-field {
317
+ padding-left: 6px;
318
+ width: 100%;
319
+ }
320
+ .chrome-toggle {
321
+ width: 32px;
322
+ text-align: right;
323
+ position: relative;
324
+ }
325
+ .chrome-icon {
326
+ margin-right: -4px;
327
+ margin-top: 12px;
328
+ cursor: pointer;
329
+ position: relative;
330
+ }
331
+ .chrome-toggle-svg {
332
+ width: 24px;
333
+ height: 24px;
334
+ border: 1px transparent solid;
335
+ border-radius: 5px;
336
+ }
337
+ .chrome-toggle-svg:hover {
338
+ background: #eee;
339
+ }
340
+ `,
341
+ ],
342
+ changeDetection: ChangeDetectionStrategy.OnPush,
343
+ preserveWhitespaces: false,
344
+ }]
345
+ }], propDecorators: { disableAlpha: [{
346
+ type: Input
347
+ }], hsl: [{
348
+ type: Input
349
+ }], rgb: [{
350
+ type: Input
351
+ }], hex: [{
352
+ type: Input
353
+ }], onChange: [{
354
+ type: Output
355
+ }] } });
356
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chrome-fields.component.js","sourceRoot":"","sources":["../../../src/lib/chrome/chrome-fields.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n} from '@angular/core';\n\nimport { isValidHex, HSLA, RGBA } from 'ngx-color';\nimport { TinyColor } from '@ctrl/tinycolor';\n\n@Component({\n  selector: 'color-chrome-fields',\n  template: `\n    <div class=\"chrome-wrap\">\n      <div class=\"chrome-fields\">\n        <ng-template [ngIf]=\"view === 'hex'\">\n          <div class=\"chrome-field\">\n            <color-editable-input\n              [style]=\"{ input: input, label: label }\"\n              label=\"hex\" [value]=\"hex\"\n              (onChange)=\"handleChange($event)\"\n            ></color-editable-input>\n          </div>\n        </ng-template>\n        <ng-template [ngIf]=\"view === 'rgb'\">\n          <div class=\"chrome-field\">\n            <color-editable-input\n              [style]=\"{ input: input, label: label }\"\n              label=\"r\" [value]=\"rgb.r\"\n              (onChange)=\"handleChange($event)\"\n            ></color-editable-input>\n          </div>\n          <div class=\"chrome-field\">\n            <color-editable-input\n              [style]=\"{ input: input, label: label }\"\n              label=\"g\" [value]=\"rgb.g\"\n              (onChange)=\"handleChange($event)\"\n            ></color-editable-input>\n          </div>\n          <div class=\"chrome-field\">\n            <color-editable-input\n              [style]=\"{ input: input, label: label }\"\n              label=\"b\" [value]=\"rgb.b\"\n              (onChange)=\"handleChange($event)\"\n            ></color-editable-input>\n          </div>\n          <div class=\"chrome-field\">\n            <color-editable-input *ngIf=\"!disableAlpha\"\n              [style]=\"{ input: input, label: label }\"\n              label=\"a\" [value]=\"rgb.a\"\n              [arrowOffset]=\"0.01\"\n              (onChange)=\"handleChange($event)\"\n            ></color-editable-input>\n          </div>\n        </ng-template>\n        <ng-template [ngIf]=\"view === 'hsl'\">\n          <div class=\"chrome-field\">\n            <color-editable-input\n              [style]=\"{ input: input, label: label }\"\n              label=\"h\"\n              [value]=\"round(hsl.h)\"\n              (onChange)=\"handleChange($event)\"\n            ></color-editable-input>\n          </div>\n          <div class=\"chrome-field\">\n            <color-editable-input\n              [style]=\"{ input: input, label: label }\"\n              label=\"s\" [value]=\"round(hsl.s * 100) + '%'\"\n              (onChange)=\"handleChange($event)\"\n            ></color-editable-input>\n          </div>\n          <div class=\"chrome-field\">\n            <color-editable-input\n              [style]=\"{ input: input, label: label }\"\n              label=\"l\" [value]=\"round(hsl.l * 100) + '%'\"\n              (onChange)=\"handleChange($event)\"\n            ></color-editable-input>\n          </div>\n          <div class=\"chrome-field\">\n            <color-editable-input *ngIf=\"!disableAlpha\"\n              [style]=\"{ input: input, label: label }\"\n              label=\"a\" [value]=\"hsl.a\"\n              [arrowOffset]=\"0.01\"\n              (onChange)=\"handleChange($event)\"\n            ></color-editable-input>\n          </div>\n        </ng-template>\n      </div>\n\n      <div class=\"chrome-toggle\">\n        <div class=\"chrome-icon\" (click)=\"toggleViews()\" #icon>\n          <svg class=\"chrome-toggle-svg\" viewBox=\"0 0 24 24\">\n            <path #iconUp fill=\"#333\"\n              d=\"M12,5.83L15.17,9L16.58,7.59L12,3L7.41,7.59L8.83,9L12,5.83Z\"\n            />\n            <path #iconDown fill=\"#333\"\n              d=\"M12,18.17L8.83,15L7.42,16.41L12,21L16.59,16.41L15.17,15Z\"\n            />\n          </svg>\n        </div>\n      </div>\n    </div>\n  `,\n  styles: [\n    `\n      .chrome-wrap {\n        padding-top: 16px;\n        display: flex;\n      }\n      .chrome-fields {\n        flex: 1;\n        display: flex;\n        margin-left: -6px;\n      }\n      .chrome-field {\n        padding-left: 6px;\n        width: 100%;\n      }\n      .chrome-toggle {\n        width: 32px;\n        text-align: right;\n        position: relative;\n      }\n      .chrome-icon {\n        margin-right: -4px;\n        margin-top: 12px;\n        cursor: pointer;\n        position: relative;\n      }\n      .chrome-toggle-svg {\n        width: 24px;\n        height: 24px;\n        border: 1px transparent solid;\n        border-radius: 5px;\n      }\n      .chrome-toggle-svg:hover {\n        background: #eee;\n      }\n    `,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n})\nexport class ChromeFieldsComponent implements OnInit {\n  @Input() disableAlpha!: boolean;\n  @Input() hsl!: HSLA;\n  @Input() rgb!: RGBA;\n  @Input() hex!: string;\n  @Output() onChange = new EventEmitter<any>();\n  view = '';\n  input: Record<string, string> = {\n    fontSize: '11px',\n    color: '#333',\n    width: '100%',\n    borderRadius: '2px',\n    border: 'none',\n    boxShadow: 'inset 0 0 0 1px #dadada',\n    height: '21px',\n    'text-align': 'center',\n  };\n  label: Record<string, string> = {\n    'text-transform': 'uppercase',\n    fontSize: '11px',\n    'line-height': '11px',\n    color: '#969696',\n    'text-align': 'center',\n    display: 'block',\n    marginTop: '12px',\n  };\n\n  ngOnInit() {\n    if (this.hsl.a === 1 && this.view !== 'hex') {\n      this.view = 'hex';\n    } else if (this.view !== 'rgb' && this.view !== 'hsl') {\n      this.view = 'rgb';\n    }\n  }\n  toggleViews() {\n    if (this.view === 'hex') {\n      this.view = 'rgb';\n    } else if (this.view === 'rgb') {\n      this.view = 'hsl';\n    } else if (this.view === 'hsl') {\n      if (this.hsl.a === 1) {\n        this.view = 'hex';\n      } else {\n        this.view = 'rgb';\n      }\n    }\n  }\n  round(value) {\n    return Math.round(value);\n  }\n  handleChange({ data, $event }) {\n    if (data.hex) {\n      if (isValidHex(data.hex)) {\n        const color = new TinyColor(data.hex);\n        this.onChange.emit({\n          data: {\n            hex: this.disableAlpha ? color.toHex() : color.toHex8(),\n            source: 'hex',\n          },\n          $event,\n        });\n      }\n    } else if (data.r || data.g || data.b) {\n      this.onChange.emit({\n        data: {\n          r: data.r || this.rgb.r,\n          g: data.g || this.rgb.g,\n          b: data.b || this.rgb.b,\n          source: 'rgb',\n        },\n        $event,\n      });\n    } else if (data.a) {\n      if (data.a < 0) {\n        data.a = 0;\n      } else if (data.a > 1) {\n        data.a = 1;\n      }\n\n      if (this.disableAlpha) {\n        data.a = 1;\n      }\n\n      this.onChange.emit({\n        data: {\n          h: this.hsl.h,\n          s: this.hsl.s,\n          l: this.hsl.l,\n          a: Math.round(data.a * 100) / 100,\n          source: 'rgb',\n        },\n        $event,\n      });\n    } else if (data.h || data.s || data.l) {\n      const s = data.s && data.s.replace('%', '');\n      const l = data.l && data.l.replace('%', '');\n      this.onChange.emit({\n        data: {\n          h: data.h || this.hsl.h,\n          s: Number(s || this.hsl.s),\n          l: Number(l || this.hsl.l),\n          source: 'hsl',\n        },\n        $event,\n      });\n    }\n  }\n}\n"]}
@@ -246,4 +246,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImpor
246
246
  ],
247
247
  }]
248
248
  }] });
249
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chrome.component.js","sourceRoot":"","sources":["../../../../src/lib/components/chrome/chrome.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAEhG,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,SAAS,EAAE,mBAAmB,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AACvH,OAAO,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAClE,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;;;AAwHnD,MAAM,OAAO,eAAgB,SAAQ,SAAS;IAoB5C;QACE,KAAK,EAAE,CAAC;QApBV,kDAAkD;QACzC,iBAAY,GAAG,KAAK,CAAC;QAC9B,WAAM,GAA2B;YAC/B,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,MAAM;YACd,YAAY,EAAE,KAAK;YACnB,SAAS,EAAE,0CAA0C;YACrD,SAAS,EAAE,uBAAuB;SACnC,CAAC;QACF,YAAO,GAA2B;YAChC,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,MAAM;YACd,YAAY,EAAE,KAAK;YACnB,SAAS,EAAE,uBAAuB;YAClC,eAAe,EAAE,oBAAoB;YACrC,SAAS,EAAE,iCAAiC;SAC7C,CAAC;IAKF,CAAC;IAED,gBAAgB;QACd,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;QACjD,IAAI,CAAC,gBAAgB,GAAG,QAAQ,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,KAAK,GAAG,CAAC;IACxF,CAAC;IACD,iBAAiB,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE;QAChC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;IAClC,CAAC;;4GA9BU,eAAe;gGAAf,eAAe,iFAZf;QACT;YACE,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC;YAC9C,KAAK,EAAE,IAAI;SACZ;QACD;YACE,OAAO,EAAE,SAAS;YAClB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC;SAC/C;KACF,iDAlHS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CT,69CA0G+B,qBAAqB;2FAlC1C,eAAe;kBAtH3B,SAAS;mBAAC;oBACT,QAAQ,EAAE,cAAc;oBACxB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4CT;oBACD,MAAM,EAAE;wBACN;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAsDC;qBACF;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,mBAAmB,EAAE,KAAK;oBAC1B,SAAS,EAAE;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,gBAAgB,CAAC;4BAC9C,KAAK,EAAE,IAAI;yBACZ;wBACD;4BACE,OAAO,EAAE,SAAS;4BAClB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,gBAAgB,CAAC;yBAC/C;qBACF;iBACF;0EAGU,YAAY;sBAApB,KAAK;;AA2CR,MAAM,OAAO,iBAAiB;;8GAAjB,iBAAiB;+GAAjB,iBAAiB,iBA7CjB,eAAe,EAkCM,qBAAqB,aAGnD,YAAY;QACZ,WAAW;QACX,gBAAgB;QAChB,mBAAmB;QACnB,SAAS;QACT,gBAAgB,aA1CP,eAAe,EAmCC,qBAAqB;+GAUrC,iBAAiB,YATnB;YACP,YAAY;YACZ,WAAW;YACX,gBAAgB;YAChB,mBAAmB;YACnB,SAAS;YACT,gBAAgB;SACjB;2FAEU,iBAAiB;kBAZ7B,QAAQ;mBAAC;oBACR,YAAY,EAAE,CAAC,eAAe,EAAE,qBAAqB,CAAC;oBACtD,OAAO,EAAE,CAAC,eAAe,EAAE,qBAAqB,CAAC;oBACjD,OAAO,EAAE;wBACP,YAAY;wBACZ,WAAW;wBACX,gBAAgB;wBAChB,mBAAmB;wBACnB,SAAS;wBACT,gBAAgB;qBACjB;iBACF","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, forwardRef, Input, NgModule } from '@angular/core';\n\nimport { AlphaModule, CheckboardModule, ColorWrap, EditableInputModule, HueModule, SaturationModule } from 'ngx-color';\nimport { ChromeFieldsComponent } from './chrome-fields.component';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'color-chrome',\n  template: `\n  <div class=\"chrome-picker {{ className }}\">\n    <div class=\"saturation\">\n      <color-saturation\n        [hsl]=\"hsl\"\n        [hsv]=\"hsv\"\n        [circle]=\"circle\"\n        (onChange)=\"handleValueChange($event)\"\n      ></color-saturation>\n    </div>\n    <div class=\"chrome-body\">\n      <div class=\"chrome-controls\">\n        <div class=\"chrome-color\">\n          <div class=\"chrome-swatch\">\n            <div class=\"chrome-active\"\n              [style.background]=\"activeBackground\"\n            ></div>\n            <color-checkboard></color-checkboard>\n          </div>\n        </div>\n        <div class=\"chrome-toggles\">\n          <div class=\"chrome-hue\">\n            <color-hue\n              [radius]=\"2\"\n              [hsl]=\"hsl\"\n              [pointer]=\"pointer\"\n              (onChange)=\"handleValueChange($event)\"\n            ></color-hue>\n          </div>\n          <div class=\"chrome-alpha\" *ngIf=\"!disableAlpha\">\n            <color-alpha\n              [radius]=\"2\" [rgb]=\"rgb\" [hsl]=\"hsl\"\n              [pointer]=\"pointer\" (onChange)=\"handleValueChange($event)\"\n            ></color-alpha>\n          </div>\n        </div>\n      </div>\n      <color-chrome-fields\n        [rgb]=\"rgb\" [hsl]=\"hsl\" [hex]=\"hex\"\n        [disableAlpha]=\"disableAlpha\"\n        (onChange)=\"handleValueChange($event)\"\n      ></color-chrome-fields>\n    </div>\n  </div>\n  `,\n  styles: [\n    `\n      .chrome-picker {\n        background: #fff;\n        border-radius: 2px;\n        box-shadow: 0 0 2px rgba(0, 0, 0, 0.3), 0 4px 8px rgba(0, 0, 0, 0.3);\n        box-sizing: initial;\n        width: 225px;\n        font-family: 'Menlo';\n      }\n      .chrome-controls {\n        display: flex;\n      }\n      .chrome-color {\n        width: 42px;\n      }\n      .chrome-body {\n        padding: 14px 14px 12px;\n      }\n      .chrome-active {\n        position: absolute;\n        top: 0;\n        bottom: 0;\n        left: 0;\n        right: 0;\n        border-radius: 20px;\n        box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.1);\n        z-index: 2;\n      }\n      .chrome-swatch {\n        width: 28px;\n        height: 28px;\n        border-radius: 15px;\n        position: relative;\n        overflow: hidden;\n      }\n      .saturation {\n        width: 100%;\n        padding-bottom: 55%;\n        position: relative;\n        border-radius: 2px 2px 0 0;\n        overflow: hidden;\n      }\n      .chrome-toggles {\n        flex: 1;\n      }\n      .chrome-hue {\n        height: 10px;\n        position: relative;\n        margin-bottom: 8px;\n      }\n      .chrome-alpha {\n        height: 10px;\n        position: relative;\n      }\n    `,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => ChromeComponent),\n      multi: true,\n    },\n    {\n      provide: ColorWrap,\n      useExisting: forwardRef(() => ChromeComponent),\n    },\n  ]\n})\nexport class ChromeComponent extends ColorWrap {\n  /** Remove alpha slider and options from picker */\n  @Input() disableAlpha = false;\n  circle: Record<string, string> = {\n    width: '12px',\n    height: '12px',\n    borderRadius: '6px',\n    boxShadow: 'rgb(255, 255, 255) 0px 0px 0px 1px inset',\n    transform: 'translate(-6px, -8px)',\n  };\n  pointer: Record<string, string> = {\n    width: '12px',\n    height: '12px',\n    borderRadius: '6px',\n    transform: 'translate(-6px, -2px)',\n    backgroundColor: 'rgb(248, 248, 248)',\n    boxShadow: '0 1px 4px 0 rgba(0, 0, 0, 0.37)',\n  };\n  activeBackground!: string;\n\n  constructor() {\n    super();\n  }\n\n  afterValidChange() {\n    const alpha = this.disableAlpha ? 1 : this.rgb.a;\n    this.activeBackground = `rgba(${this.rgb.r}, ${this.rgb.g}, ${this.rgb.b}, ${alpha})`;\n  }\n  handleValueChange({ data, $event }) {\n    this.handleChange(data, $event);\n  }\n}\n\n@NgModule({\n  declarations: [ChromeComponent, ChromeFieldsComponent],\n  exports: [ChromeComponent, ChromeFieldsComponent],\n  imports: [\n    CommonModule,\n    AlphaModule,\n    CheckboardModule,\n    EditableInputModule,\n    HueModule,\n    SaturationModule,\n  ],\n})\nexport class ColorChromeModule {}\n"]}
249
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chrome.component.js","sourceRoot":"","sources":["../../../src/lib/chrome/chrome.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, forwardRef, Input, NgModule } from '@angular/core';\n\nimport { AlphaModule, CheckboardModule, ColorWrap, EditableInputModule, HueModule, SaturationModule } from 'ngx-color';\nimport { ChromeFieldsComponent } from './chrome-fields.component';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'color-chrome',\n  template: `\n  <div class=\"chrome-picker {{ className }}\">\n    <div class=\"saturation\">\n      <color-saturation\n        [hsl]=\"hsl\"\n        [hsv]=\"hsv\"\n        [circle]=\"circle\"\n        (onChange)=\"handleValueChange($event)\"\n      ></color-saturation>\n    </div>\n    <div class=\"chrome-body\">\n      <div class=\"chrome-controls\">\n        <div class=\"chrome-color\">\n          <div class=\"chrome-swatch\">\n            <div class=\"chrome-active\"\n              [style.background]=\"activeBackground\"\n            ></div>\n            <color-checkboard></color-checkboard>\n          </div>\n        </div>\n        <div class=\"chrome-toggles\">\n          <div class=\"chrome-hue\">\n            <color-hue\n              [radius]=\"2\"\n              [hsl]=\"hsl\"\n              [pointer]=\"pointer\"\n              (onChange)=\"handleValueChange($event)\"\n            ></color-hue>\n          </div>\n          <div class=\"chrome-alpha\" *ngIf=\"!disableAlpha\">\n            <color-alpha\n              [radius]=\"2\" [rgb]=\"rgb\" [hsl]=\"hsl\"\n              [pointer]=\"pointer\" (onChange)=\"handleValueChange($event)\"\n            ></color-alpha>\n          </div>\n        </div>\n      </div>\n      <color-chrome-fields\n        [rgb]=\"rgb\" [hsl]=\"hsl\" [hex]=\"hex\"\n        [disableAlpha]=\"disableAlpha\"\n        (onChange)=\"handleValueChange($event)\"\n      ></color-chrome-fields>\n    </div>\n  </div>\n  `,\n  styles: [\n    `\n      .chrome-picker {\n        background: #fff;\n        border-radius: 2px;\n        box-shadow: 0 0 2px rgba(0, 0, 0, 0.3), 0 4px 8px rgba(0, 0, 0, 0.3);\n        box-sizing: initial;\n        width: 225px;\n        font-family: 'Menlo';\n      }\n      .chrome-controls {\n        display: flex;\n      }\n      .chrome-color {\n        width: 42px;\n      }\n      .chrome-body {\n        padding: 14px 14px 12px;\n      }\n      .chrome-active {\n        position: absolute;\n        top: 0;\n        bottom: 0;\n        left: 0;\n        right: 0;\n        border-radius: 20px;\n        box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.1);\n        z-index: 2;\n      }\n      .chrome-swatch {\n        width: 28px;\n        height: 28px;\n        border-radius: 15px;\n        position: relative;\n        overflow: hidden;\n      }\n      .saturation {\n        width: 100%;\n        padding-bottom: 55%;\n        position: relative;\n        border-radius: 2px 2px 0 0;\n        overflow: hidden;\n      }\n      .chrome-toggles {\n        flex: 1;\n      }\n      .chrome-hue {\n        height: 10px;\n        position: relative;\n        margin-bottom: 8px;\n      }\n      .chrome-alpha {\n        height: 10px;\n        position: relative;\n      }\n    `,\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => ChromeComponent),\n      multi: true,\n    },\n    {\n      provide: ColorWrap,\n      useExisting: forwardRef(() => ChromeComponent),\n    },\n  ]\n})\nexport class ChromeComponent extends ColorWrap {\n  /** Remove alpha slider and options from picker */\n  @Input() disableAlpha = false;\n  circle: Record<string, string> = {\n    width: '12px',\n    height: '12px',\n    borderRadius: '6px',\n    boxShadow: 'rgb(255, 255, 255) 0px 0px 0px 1px inset',\n    transform: 'translate(-6px, -8px)',\n  };\n  pointer: Record<string, string> = {\n    width: '12px',\n    height: '12px',\n    borderRadius: '6px',\n    transform: 'translate(-6px, -2px)',\n    backgroundColor: 'rgb(248, 248, 248)',\n    boxShadow: '0 1px 4px 0 rgba(0, 0, 0, 0.37)',\n  };\n  activeBackground!: string;\n\n  constructor() {\n    super();\n  }\n\n  afterValidChange() {\n    const alpha = this.disableAlpha ? 1 : this.rgb.a;\n    this.activeBackground = `rgba(${this.rgb.r}, ${this.rgb.g}, ${this.rgb.b}, ${alpha})`;\n  }\n  handleValueChange({ data, $event }) {\n    this.handleChange(data, $event);\n  }\n}\n\n@NgModule({\n  declarations: [ChromeComponent, ChromeFieldsComponent],\n  exports: [ChromeComponent, ChromeFieldsComponent],\n  imports: [\n    CommonModule,\n    AlphaModule,\n    CheckboardModule,\n    EditableInputModule,\n    HueModule,\n    SaturationModule,\n  ],\n})\nexport class ColorChromeModule {}\n"]}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public_api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWNvbG9yLWNocm9tZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvY2hyb21lL25neC1jb2xvci1jaHJvbWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWNfYXBpJztcbiJdfQ==
@@ -0,0 +1,3 @@
1
+ export { ChromeFieldsComponent } from './chrome-fields.component';
2
+ export { ChromeComponent, ColorChromeModule } from './chrome.component';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvY2hyb21lL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQ2hyb21lRmllbGRzQ29tcG9uZW50IH0gZnJvbSAnLi9jaHJvbWUtZmllbGRzLmNvbXBvbmVudCc7XG5leHBvcnQgeyBDaHJvbWVDb21wb25lbnQsIENvbG9yQ2hyb21lTW9kdWxlIH0gZnJvbSAnLi9jaHJvbWUuY29tcG9uZW50JztcbiJdfQ==
@@ -0,0 +1,85 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "ngx-color";
4
+ export class CircleSwatchComponent {
5
+ constructor() {
6
+ this.circleSize = 28;
7
+ this.circleSpacing = 14;
8
+ this.focus = false;
9
+ this.onClick = new EventEmitter();
10
+ this.onSwatchHover = new EventEmitter();
11
+ this.focusStyle = {};
12
+ this.swatchStyle = {
13
+ borderRadius: '50%',
14
+ background: 'transparent',
15
+ transition: '100ms box-shadow ease 0s',
16
+ };
17
+ }
18
+ ngOnChanges() {
19
+ this.swatchStyle.boxShadow = `inset 0 0 0 ${this.circleSize / 2}px ${this.color}`;
20
+ this.focusStyle.boxShadow = `inset 0 0 0 ${this.circleSize / 2}px ${this.color}, 0 0 5px ${this.color}`;
21
+ if (this.focus) {
22
+ this.focusStyle.boxShadow = `inset 0 0 0 3px ${this.color}, 0 0 5px ${this.color}`;
23
+ }
24
+ }
25
+ handleClick({ hex, $event }) {
26
+ this.onClick.emit({ hex, $event });
27
+ }
28
+ }
29
+ CircleSwatchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: CircleSwatchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
30
+ CircleSwatchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.0", type: CircleSwatchComponent, selector: "color-circle-swatch", inputs: { color: "color", circleSize: "circleSize", circleSpacing: "circleSpacing", focus: "focus" }, outputs: { onClick: "onClick", onSwatchHover: "onSwatchHover" }, usesOnChanges: true, ngImport: i0, template: `
31
+ <div class="circle-swatch"
32
+ [style.width.px]="circleSize" [style.height.px]="circleSize"
33
+ [style.margin-right.px]="circleSpacing" [style.margin-bottom.px]="circleSpacing"
34
+ >
35
+ <color-swatch
36
+ [color]="color" [style]="swatchStyle" [focus]="focus" [focusStyle]="focusStyle"
37
+ (onClick)="handleClick($event)" (onHover)="onSwatchHover.emit($event)">
38
+ </color-swatch>
39
+ <div class="clear"></div>
40
+ </div>
41
+ `, isInline: true, styles: [".circle-swatch{transform:scale(1);transition:transform .1s ease}.circle-swatch:hover{transform:scale(1.2)}\n"], components: [{ type: i1.SwatchComponent, selector: "color-swatch", inputs: ["color", "style", "focusStyle", "focus"], outputs: ["onClick", "onHover"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
42
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.0", ngImport: i0, type: CircleSwatchComponent, decorators: [{
43
+ type: Component,
44
+ args: [{
45
+ selector: 'color-circle-swatch',
46
+ template: `
47
+ <div class="circle-swatch"
48
+ [style.width.px]="circleSize" [style.height.px]="circleSize"
49
+ [style.margin-right.px]="circleSpacing" [style.margin-bottom.px]="circleSpacing"
50
+ >
51
+ <color-swatch
52
+ [color]="color" [style]="swatchStyle" [focus]="focus" [focusStyle]="focusStyle"
53
+ (onClick)="handleClick($event)" (onHover)="onSwatchHover.emit($event)">
54
+ </color-swatch>
55
+ <div class="clear"></div>
56
+ </div>
57
+ `,
58
+ styles: [
59
+ `
60
+ .circle-swatch {
61
+ transform: scale(1);
62
+ transition: transform 100ms ease;
63
+ }
64
+ .circle-swatch:hover {
65
+ transform: scale(1.2);
66
+ }
67
+ `,
68
+ ],
69
+ changeDetection: ChangeDetectionStrategy.OnPush,
70
+ preserveWhitespaces: false,
71
+ }]
72
+ }], propDecorators: { color: [{
73
+ type: Input
74
+ }], circleSize: [{
75
+ type: Input
76
+ }], circleSpacing: [{
77
+ type: Input
78
+ }], focus: [{
79
+ type: Input
80
+ }], onClick: [{
81
+ type: Output
82
+ }], onSwatchHover: [{
83
+ type: Output
84
+ }] } });
85
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2lyY2xlLXN3YXRjaC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbGliL2NpcmNsZS9jaXJjbGUtc3dhdGNoLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUVMLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQzs7O0FBOEJ2QixNQUFNLE9BQU8scUJBQXFCO0lBNUJsQztRQThCVyxlQUFVLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLGtCQUFhLEdBQUcsRUFBRSxDQUFDO1FBQ25CLFVBQUssR0FBRyxLQUFLLENBQUM7UUFDYixZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUNsQyxrQkFBYSxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFDbEQsZUFBVSxHQUEyQixFQUFFLENBQUM7UUFDeEMsZ0JBQVcsR0FBMkI7WUFDcEMsWUFBWSxFQUFFLEtBQUs7WUFDbkIsVUFBVSxFQUFFLGFBQWE7WUFDekIsVUFBVSxFQUFFLDBCQUEwQjtTQUN2QyxDQUFDO0tBWUg7SUFWQyxXQUFXO1FBQ1QsSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTLEdBQUcsZUFBZSxJQUFJLENBQUMsVUFBVSxHQUFHLENBQUMsTUFBTSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7UUFDbEYsSUFBSSxDQUFDLFVBQVUsQ0FBQyxTQUFTLEdBQUcsZUFBZ0IsSUFBSSxDQUFDLFVBQVUsR0FBRyxDQUFFLE1BQU8sSUFBSSxDQUFDLEtBQU0sYUFBYyxJQUFJLENBQUMsS0FBTSxFQUFFLENBQUM7UUFDOUcsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ2QsSUFBSSxDQUFDLFVBQVUsQ0FBQyxTQUFTLEdBQUcsbUJBQW9CLElBQUksQ0FBQyxLQUFNLGFBQWMsSUFBSSxDQUFDLEtBQU0sRUFBRSxDQUFDO1NBQ3hGO0lBQ0gsQ0FBQztJQUNELFdBQVcsQ0FBQyxFQUFFLEdBQUcsRUFBRSxNQUFNLEVBQUU7UUFDekIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxHQUFHLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztJQUNyQyxDQUFDOztrSEF2QlUscUJBQXFCO3NHQUFyQixxQkFBcUIsdVBBMUJ0Qjs7Ozs7Ozs7Ozs7R0FXVDsyRkFlVSxxQkFBcUI7a0JBNUJqQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxxQkFBcUI7b0JBQy9CLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7R0FXVDtvQkFDRCxNQUFNLEVBQUU7d0JBQ047Ozs7Ozs7O0dBUUQ7cUJBQ0E7b0JBQ0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLG1CQUFtQixFQUFFLEtBQUs7aUJBQzNCOzhCQUVVLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNJLE9BQU87c0JBQWhCLE1BQU07Z0JBQ0csYUFBYTtzQkFBdEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgT3V0cHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnY29sb3ItY2lyY2xlLXN3YXRjaCcsXG4gIHRlbXBsYXRlOiBgXG4gIDxkaXYgY2xhc3M9XCJjaXJjbGUtc3dhdGNoXCJcbiAgICBbc3R5bGUud2lkdGgucHhdPVwiY2lyY2xlU2l6ZVwiIFtzdHlsZS5oZWlnaHQucHhdPVwiY2lyY2xlU2l6ZVwiXG4gICAgW3N0eWxlLm1hcmdpbi1yaWdodC5weF09XCJjaXJjbGVTcGFjaW5nXCIgW3N0eWxlLm1hcmdpbi1ib3R0b20ucHhdPVwiY2lyY2xlU3BhY2luZ1wiXG4gICAgPlxuICAgIDxjb2xvci1zd2F0Y2hcbiAgICAgIFtjb2xvcl09XCJjb2xvclwiIFtzdHlsZV09XCJzd2F0Y2hTdHlsZVwiIFtmb2N1c109XCJmb2N1c1wiIFtmb2N1c1N0eWxlXT1cImZvY3VzU3R5bGVcIlxuICAgICAgKG9uQ2xpY2spPVwiaGFuZGxlQ2xpY2soJGV2ZW50KVwiIChvbkhvdmVyKT1cIm9uU3dhdGNoSG92ZXIuZW1pdCgkZXZlbnQpXCI+XG4gICAgPC9jb2xvci1zd2F0Y2g+XG4gICAgPGRpdiBjbGFzcz1cImNsZWFyXCI+PC9kaXY+XG4gIDwvZGl2PlxuICBgLFxuICBzdHlsZXM6IFtcbiAgICBgXG4gIC5jaXJjbGUtc3dhdGNoIHtcbiAgICB0cmFuc2Zvcm06IHNjYWxlKDEpO1xuICAgIHRyYW5zaXRpb246IHRyYW5zZm9ybSAxMDBtcyBlYXNlO1xuICB9XG4gIC5jaXJjbGUtc3dhdGNoOmhvdmVyIHtcbiAgICB0cmFuc2Zvcm06IHNjYWxlKDEuMik7XG4gIH1cbiAgYCxcbiAgXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHByZXNlcnZlV2hpdGVzcGFjZXM6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBDaXJjbGVTd2F0Y2hDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xuICBASW5wdXQoKSBjb2xvciE6IHN0cmluZztcbiAgQElucHV0KCkgY2lyY2xlU2l6ZSA9IDI4O1xuICBASW5wdXQoKSBjaXJjbGVTcGFjaW5nID0gMTQ7XG4gIEBJbnB1dCgpIGZvY3VzID0gZmFsc2U7XG4gIEBPdXRwdXQoKSBvbkNsaWNrID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG4gIEBPdXRwdXQoKSBvblN3YXRjaEhvdmVyID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG4gIGZvY3VzU3R5bGU6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4gPSB7fTtcbiAgc3dhdGNoU3R5bGU6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4gPSB7XG4gICAgYm9yZGVyUmFkaXVzOiAnNTAlJyxcbiAgICBiYWNrZ3JvdW5kOiAndHJhbnNwYXJlbnQnLFxuICAgIHRyYW5zaXRpb246ICcxMDBtcyBib3gtc2hhZG93IGVhc2UgMHMnLFxuICB9O1xuXG4gIG5nT25DaGFuZ2VzKCkge1xuICAgIHRoaXMuc3dhdGNoU3R5bGUuYm94U2hhZG93ID0gYGluc2V0IDAgMCAwICR7dGhpcy5jaXJjbGVTaXplIC8gMn1weCAke3RoaXMuY29sb3J9YDtcbiAgICB0aGlzLmZvY3VzU3R5bGUuYm94U2hhZG93ID0gYGluc2V0IDAgMCAwICR7IHRoaXMuY2lyY2xlU2l6ZSAvIDIgfXB4ICR7IHRoaXMuY29sb3IgfSwgMCAwIDVweCAkeyB0aGlzLmNvbG9yIH1gO1xuICAgIGlmICh0aGlzLmZvY3VzKSB7XG4gICAgICB0aGlzLmZvY3VzU3R5bGUuYm94U2hhZG93ID0gYGluc2V0IDAgMCAwIDNweCAkeyB0aGlzLmNvbG9yIH0sIDAgMCA1cHggJHsgdGhpcy5jb2xvciB9YDtcbiAgICB9XG4gIH1cbiAgaGFuZGxlQ2xpY2soeyBoZXgsICRldmVudCB9KSB7XG4gICAgdGhpcy5vbkNsaWNrLmVtaXQoeyBoZXgsICRldmVudCB9KTtcbiAgfVxufVxuIl19