@provoly/dashboard 0.18.1 → 0.18.3

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 (81) hide show
  1. package/assets/svgs/clear_filter.svg +12 -0
  2. package/assets/svgs/refresh_data.svg +15 -0
  3. package/assets/svgs/refresh_filter.svg +13 -0
  4. package/components/color-picker/color-picker.component.d.ts +58 -0
  5. package/components/color-picker/color-picker.module.d.ts +9 -0
  6. package/components/color-picker/index.d.ts +5 -0
  7. package/components/color-picker/public-api.d.ts +2 -0
  8. package/components/scheme-picker/index.d.ts +5 -0
  9. package/components/scheme-picker/public-api.d.ts +3 -0
  10. package/components/scheme-picker/scheme-picker.component.d.ts +34 -0
  11. package/components/scheme-picker/scheme-picker.module.d.ts +11 -0
  12. package/components/scheme-picker/scheme.service.d.ts +12 -0
  13. package/dataset/components/dataset-card/dataset-card.component.d.ts +11 -3
  14. package/dataset/i18n/en.translations.d.ts +1 -0
  15. package/dataset/i18n/fr.translations.d.ts +1 -0
  16. package/dataset/style/_o-pry-dataset-card.scss +16 -1
  17. package/dataset/style/_o-pry-dataset.scss +18 -3
  18. package/esm2022/admin/components/admin-dataset/shared/admin-form-dataset/admin-form-dataset.component.mjs +7 -5
  19. package/esm2022/components/color-picker/color-picker.component.mjs +314 -0
  20. package/esm2022/components/color-picker/color-picker.module.mjs +20 -0
  21. package/esm2022/components/color-picker/provoly-dashboard-components-color-picker.mjs +5 -0
  22. package/esm2022/components/color-picker/public-api.mjs +3 -0
  23. package/esm2022/components/scheme-picker/provoly-dashboard-components-scheme-picker.mjs +5 -0
  24. package/esm2022/components/scheme-picker/public-api.mjs +4 -0
  25. package/esm2022/components/scheme-picker/scheme-picker.component.mjs +104 -0
  26. package/esm2022/components/scheme-picker/scheme-picker.module.mjs +22 -0
  27. package/esm2022/components/scheme-picker/scheme.service.mjs +47 -0
  28. package/esm2022/dataset/components/dataset-card/dataset-card.component.mjs +26 -9
  29. package/esm2022/dataset/components/dataset-detail/dataset-detail.component.mjs +3 -3
  30. package/esm2022/dataset/components/dataset.component.mjs +3 -3
  31. package/esm2022/dataset/i18n/en.translations.mjs +2 -1
  32. package/esm2022/dataset/i18n/fr.translations.mjs +2 -1
  33. package/esm2022/dataset/style/css.component.mjs +2 -2
  34. package/esm2022/lib/core/i18n/en.translations.mjs +6 -2
  35. package/esm2022/lib/core/i18n/fr.translations.mjs +6 -2
  36. package/esm2022/lib/core/model/widget-aggregated-chart-manifest.interface.mjs +1 -1
  37. package/esm2022/lib/core/model/widget-chart-manifest.interface.mjs +2 -1
  38. package/esm2022/lib/core/store/aggregation/backend-aggregation.service.mjs +4 -1
  39. package/esm2022/lib/core/store/data-source/data-source.model.mjs +1 -1
  40. package/esm2022/restitution/components/restitution/restitution.component.mjs +11 -20
  41. package/esm2022/restitution/model/restitution.model.mjs +1 -1
  42. package/esm2022/widgets/widget-aggregated-chart/component/widget-aggregated-chart.component.mjs +149 -31
  43. package/esm2022/widgets/widget-aggregated-chart/i18n/en.translations.mjs +19 -2
  44. package/esm2022/widgets/widget-aggregated-chart/i18n/fr.translations.mjs +19 -2
  45. package/esm2022/widgets/widget-aggregated-chart/widget-aggregated-chart.module.mjs +16 -5
  46. package/esm2022/widgets/widget-chart/i18n/en.translations.mjs +3 -2
  47. package/esm2022/widgets/widget-chart/i18n/fr.translations.mjs +3 -2
  48. package/fesm2022/provoly-dashboard-admin.mjs +6 -4
  49. package/fesm2022/provoly-dashboard-admin.mjs.map +1 -1
  50. package/fesm2022/provoly-dashboard-components-color-picker.mjs +337 -0
  51. package/fesm2022/provoly-dashboard-components-color-picker.mjs.map +1 -0
  52. package/fesm2022/provoly-dashboard-components-scheme-picker.mjs +171 -0
  53. package/fesm2022/provoly-dashboard-components-scheme-picker.mjs.map +1 -0
  54. package/fesm2022/provoly-dashboard-dataset.mjs +29 -14
  55. package/fesm2022/provoly-dashboard-dataset.mjs.map +1 -1
  56. package/fesm2022/provoly-dashboard-restitution.mjs +10 -19
  57. package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
  58. package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs +198 -35
  59. package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs.map +1 -1
  60. package/fesm2022/provoly-dashboard-widgets-widget-chart.mjs +4 -2
  61. package/fesm2022/provoly-dashboard-widgets-widget-chart.mjs.map +1 -1
  62. package/fesm2022/provoly-dashboard.mjs +16 -2
  63. package/fesm2022/provoly-dashboard.mjs.map +1 -1
  64. package/lib/core/i18n/en.translations.d.ts +4 -0
  65. package/lib/core/i18n/fr.translations.d.ts +4 -0
  66. package/lib/core/model/widget-aggregated-chart-manifest.interface.d.ts +7 -0
  67. package/lib/core/model/widget-chart-manifest.interface.d.ts +1 -0
  68. package/lib/core/store/data-source/data-source.model.d.ts +0 -2
  69. package/package.json +47 -35
  70. package/restitution/components/restitution/restitution.component.d.ts +0 -2
  71. package/restitution/model/restitution.model.d.ts +1 -1
  72. package/styles/components/_a-color-picker.scss +62 -0
  73. package/styles/components/_m-color-scheme.scss +20 -0
  74. package/styles/main.scss +2 -0
  75. package/styles-theme/components-theme/_o-pry-admin-classes-customize.theme.scss +4 -0
  76. package/widgets/widget-aggregated-chart/component/widget-aggregated-chart.component.d.ts +18 -5
  77. package/widgets/widget-aggregated-chart/i18n/en.translations.d.ts +17 -0
  78. package/widgets/widget-aggregated-chart/i18n/fr.translations.d.ts +17 -0
  79. package/widgets/widget-aggregated-chart/widget-aggregated-chart.module.d.ts +3 -1
  80. package/widgets/widget-chart/i18n/en.translations.d.ts +1 -0
  81. package/widgets/widget-chart/i18n/fr.translations.d.ts +1 -0
@@ -0,0 +1,314 @@
1
+ import { Component, forwardRef, ViewChild } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/forms";
5
+ export class PryColorPickerComponent {
6
+ constructor(_cd) {
7
+ this._cd = _cd;
8
+ this.onChange = () => { };
9
+ this.onTouch = () => { };
10
+ this.color = '#000000';
11
+ this.barColor = '#0000ff';
12
+ this.disabled = false;
13
+ this.inhibate = true;
14
+ this.picking = false;
15
+ this.markerSelectorPosition = [0, 0];
16
+ this.markerBarPosition = 0;
17
+ this.innerRadius = 3;
18
+ this.outerRadius = 8;
19
+ }
20
+ registerOnChange(fn) {
21
+ this.onChange = fn;
22
+ }
23
+ registerOnTouched(fn) {
24
+ this.onTouch = fn;
25
+ }
26
+ // Define what should happen in this component, if something changes outside
27
+ writeValue(color) {
28
+ if (this.color !== color && !this.inhibate) {
29
+ this.color = color;
30
+ this.onChange(this.color);
31
+ this.onTouch();
32
+ this._cd.markForCheck();
33
+ this.inputColor(color);
34
+ }
35
+ }
36
+ setDisabledState(isDisabled) {
37
+ this.disabled = isDisabled;
38
+ this._cd.markForCheck();
39
+ }
40
+ ngAfterViewInit() {
41
+ this.inhibate = false;
42
+ this.selectorContext = this.selector.nativeElement.getContext('2d', { willReadFrequently: true });
43
+ this.barContext = this.bar.nativeElement.getContext('2d', { willReadFrequently: true });
44
+ }
45
+ togglePicker($event) {
46
+ this.picking = !this.disabled && !this.picking;
47
+ if (!this.picking && this.temporaryColor) {
48
+ this.writeValue(this.temporaryColor);
49
+ }
50
+ if (this.picking) {
51
+ this.redrawSelector();
52
+ this.redrawBar();
53
+ }
54
+ }
55
+ redrawSelector() {
56
+ this.selectorContext.clearRect(0, 0, this.selectorContext.canvas.width, this.selectorContext.canvas.height);
57
+ this.drawColorGradient(this.selectorContext, false, ['#ffffff', this.barColor]);
58
+ this.drawColorGradient(this.selectorContext, true, ['rgba(0,0,0,0)', '#000']);
59
+ this.drawSelectorMarker();
60
+ }
61
+ redrawBar() {
62
+ this.barContext.clearRect(0, 0, this.barContext.canvas.width, this.barContext.canvas.height);
63
+ this.drawColorGradient(this.barContext, true, [
64
+ '#FF0000',
65
+ '#ffff00',
66
+ '#00FF00',
67
+ '#00FFFF',
68
+ '#0000FF',
69
+ '#FF00FF',
70
+ '#FF0000'
71
+ ]);
72
+ this.drawBarMarker();
73
+ }
74
+ drawColorGradient(ctxt, vertical = true, colors) {
75
+ const gradientArgs = vertical
76
+ ? [0, 0, 0, ctxt.canvas.height]
77
+ : [0, 0, ctxt.canvas.width, 0];
78
+ let gradient = ctxt.createLinearGradient(...gradientArgs);
79
+ colors.forEach((color, idx) => {
80
+ gradient.addColorStop(idx / (colors.length - 1), color);
81
+ });
82
+ ctxt.fillStyle = gradient;
83
+ ctxt.fillRect(0, 0, ctxt.canvas.width, ctxt.canvas.height);
84
+ }
85
+ drawSelectorMarker() {
86
+ const gradient = this.selectorContext.createRadialGradient(this.markerSelectorPosition[0], this.markerSelectorPosition[1], this.innerRadius, this.markerSelectorPosition[0], this.markerSelectorPosition[1], this.outerRadius);
87
+ gradient.addColorStop(0, 'rgba(0,0,0,0)');
88
+ gradient.addColorStop(1, '#ffffff');
89
+ this.selectorContext.beginPath();
90
+ this.selectorContext.arc(this.markerSelectorPosition[0], this.markerSelectorPosition[1], this.outerRadius, 0, 2 * Math.PI);
91
+ this.selectorContext.fillStyle = gradient;
92
+ this.selectorContext.fill();
93
+ this.selectorContext.stroke();
94
+ }
95
+ drawBarMarker() {
96
+ this.barContext.strokeStyle = '2px solid black';
97
+ this.barContext.beginPath();
98
+ this.barContext.moveTo(0, this.markerBarPosition - this.innerRadius);
99
+ this.barContext.lineTo(this.barContext.canvas.width, this.markerBarPosition - this.innerRadius);
100
+ this.barContext.stroke();
101
+ this.barContext.beginPath();
102
+ this.barContext.moveTo(0, this.markerBarPosition + this.innerRadius);
103
+ this.barContext.lineTo(this.barContext.canvas.width, this.markerBarPosition + this.innerRadius);
104
+ this.barContext.stroke();
105
+ }
106
+ selectColor($event, temporary = false) {
107
+ // Read pixel Color
108
+ const pixelColor = this.rgbToHex(...this.selectorContext.getImageData($event.offsetX, $event.offsetY, 1, 1)['data']);
109
+ if (!temporary) {
110
+ this.writeValue(pixelColor);
111
+ }
112
+ else {
113
+ this.temporaryColor = pixelColor;
114
+ }
115
+ this.markerSelectorPosition = [$event.offsetX, $event.offsetY];
116
+ this.redrawSelector();
117
+ $event.stopPropagation();
118
+ }
119
+ selectColorFromBar($event) {
120
+ this.markerBarPosition = $event.offsetY;
121
+ this.barColor = this.rgbToHex(...this.barContext.getImageData(20, $event.offsetY, 1, 1)['data']);
122
+ this.redrawBar();
123
+ this.redrawSelector();
124
+ this.selectColor({
125
+ offsetX: this.markerSelectorPosition[0],
126
+ offsetY: this.markerSelectorPosition[1],
127
+ stopPropagation: () => $event.stopPropagation()
128
+ }, true);
129
+ $event.stopPropagation();
130
+ }
131
+ componentToHex(c) {
132
+ return c.toString(16).padStart(2, '0');
133
+ }
134
+ rgbToHex(r, g, b) {
135
+ return '#' + this.componentToHex(r) + this.componentToHex(g) + this.componentToHex(b);
136
+ }
137
+ clickInput($event) {
138
+ this.input.nativeElement.focus();
139
+ $event.stopPropagation();
140
+ }
141
+ inputColor($event) {
142
+ const possibleColor = !!$event ? ($event.indexOf('#') === -1 ? '#' + $event : $event) : '#FFFFFF';
143
+ if (/^#[0-9A-F]{6}$/i.test(possibleColor)) {
144
+ this.writeValue(possibleColor);
145
+ const rgba = this.strToRGBA(this.color);
146
+ const hsva = this.RGBAtoHSVA(rgba);
147
+ this.markerBarPosition = (this.barContext.canvas.height * hsva.h) / 360;
148
+ this.markerSelectorPosition = [
149
+ (this.selectorContext.canvas.width * hsva.s) / 100,
150
+ this.selectorContext.canvas.height * (1 - hsva.v / 100)
151
+ ];
152
+ this.barColor = this.hslToHex(hsva.h, 100, 50);
153
+ this.redrawBar();
154
+ this.redrawSelector();
155
+ }
156
+ }
157
+ strToRGBA(str) {
158
+ const regex = /^((rgba)|rgb)[\D]+([\d.]+)[\D]+([\d.]+)[\D]+([\d.]+)[\D]*?([\d.]+|$)/i;
159
+ let match, rgba;
160
+ // Default to black for invalid color strings
161
+ this.selectorContext.fillStyle = '#000';
162
+ // Use canvas to convert the string to a valid color string
163
+ this.selectorContext.fillStyle = str;
164
+ match = regex.exec(this.selectorContext.fillStyle);
165
+ if (match) {
166
+ rgba = {
167
+ // @ts-ignore
168
+ r: match[3] * 1,
169
+ // @ts-ignore
170
+ g: match[4] * 1,
171
+ // @ts-ignore
172
+ b: match[5] * 1,
173
+ // @ts-ignore
174
+ a: match[6] * 1
175
+ };
176
+ // Workaround to mitigate a Chromium bug where the alpha value is rounded incorrectly
177
+ rgba.a = +rgba.a.toFixed(2);
178
+ }
179
+ else {
180
+ match = this.selectorContext.fillStyle
181
+ .replace('#', '')
182
+ .match(/.{2}/g)
183
+ .map((h) => parseInt(h, 16));
184
+ rgba = {
185
+ r: match[0],
186
+ g: match[1],
187
+ b: match[2],
188
+ a: 1
189
+ };
190
+ }
191
+ return rgba;
192
+ }
193
+ RGBAtoHSVA(rgba) {
194
+ const red = rgba.r / 255;
195
+ const green = rgba.g / 255;
196
+ const blue = rgba.b / 255;
197
+ const xmax = Math.max(red, green, blue);
198
+ const xmin = Math.min(red, green, blue);
199
+ const chroma = xmax - xmin;
200
+ const value = xmax;
201
+ let hue = 0;
202
+ let saturation = 0;
203
+ if (chroma) {
204
+ if (xmax === red) {
205
+ hue = (green - blue) / chroma;
206
+ }
207
+ if (xmax === green) {
208
+ hue = 2 + (blue - red) / chroma;
209
+ }
210
+ if (xmax === blue) {
211
+ hue = 4 + (red - green) / chroma;
212
+ }
213
+ if (xmax) {
214
+ saturation = chroma / xmax;
215
+ }
216
+ }
217
+ hue = Math.floor(hue * 60);
218
+ return {
219
+ h: hue < 0 ? hue + 360 : hue,
220
+ s: Math.round(saturation * 100),
221
+ v: Math.round(value * 100),
222
+ a: rgba.a
223
+ };
224
+ }
225
+ hslToHex(h, s, l) {
226
+ s /= 100;
227
+ l /= 100;
228
+ let c = (1 - Math.abs(2 * l - 1)) * s, x = c * (1 - Math.abs(((h / 60) % 2) - 1)), m = l - c / 2, r = 0, g = 0, b = 0;
229
+ if (0 <= h && h < 60) {
230
+ r = c;
231
+ g = x;
232
+ b = 0;
233
+ }
234
+ else if (60 <= h && h < 120) {
235
+ r = x;
236
+ g = c;
237
+ b = 0;
238
+ }
239
+ else if (120 <= h && h < 180) {
240
+ r = 0;
241
+ g = c;
242
+ b = x;
243
+ }
244
+ else if (180 <= h && h < 240) {
245
+ r = 0;
246
+ g = x;
247
+ b = c;
248
+ }
249
+ else if (240 <= h && h < 300) {
250
+ r = x;
251
+ g = 0;
252
+ b = c;
253
+ }
254
+ else if (300 <= h && h < 360) {
255
+ r = c;
256
+ g = 0;
257
+ b = x;
258
+ }
259
+ // Having obtained RGB, convert channels to hex
260
+ // @ts-ignore
261
+ r = Math.round((r + m) * 255).toString(16);
262
+ // @ts-ignore
263
+ g = Math.round((g + m) * 255).toString(16);
264
+ // @ts-ignore
265
+ b = Math.round((b + m) * 255).toString(16);
266
+ // Prepend 0s, if necessary
267
+ // @ts-ignore
268
+ if (r.length == 1)
269
+ r = '0' + r;
270
+ // @ts-ignore
271
+ if (g.length == 1)
272
+ g = '0' + g;
273
+ // @ts-ignore
274
+ if (b.length == 1)
275
+ b = '0' + b;
276
+ return '#' + r + g + b;
277
+ }
278
+ mouseMove($event) {
279
+ if ($event.buttons > 0) {
280
+ this.selectColor($event, true);
281
+ }
282
+ }
283
+ mouseUp($event) {
284
+ this.selectColor($event, false);
285
+ }
286
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryColorPickerComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
287
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PryColorPickerComponent, selector: "pry-color-picker", providers: [
288
+ {
289
+ provide: NG_VALUE_ACCESSOR,
290
+ useExisting: forwardRef(() => PryColorPickerComponent),
291
+ multi: true
292
+ }
293
+ ], viewQueries: [{ propertyName: "selector", first: true, predicate: ["selector"], descendants: true }, { propertyName: "bar", first: true, predicate: ["bar"], descendants: true }, { propertyName: "input", first: true, predicate: ["input"], descendants: true }], ngImport: i0, template: "<div\n class=\"a-color-picker\"\n (click)=\"togglePicker($event)\"\n [style.background-color]=\"temporaryColor ?? color\"\n [title]=\"color\"\n role=\"button\"\n>\n <div class=\"a-color-picker__modal\" [style.display]=\"picking ? 'flex' : 'none'\">\n <div class=\"a-color-picker__modal__backdrop\">\n <canvas\n #selector\n class=\"a-color-picker__modal__selector\"\n (mousemove)=\"mouseMove($event)\"\n (mouseup)=\"mouseUp($event)\"\n height=\"300\"\n width=\"300\"\n ></canvas>\n <canvas\n #bar\n class=\"a-color-picker__modal__bar\"\n (click)=\"selectColorFromBar($event)\"\n height=\"300\"\n width=\"40\"\n ></canvas>\n <div class=\"a-color-picker__modal__input\" (click)=\"clickInput($event)\">\n #<input [ngModel]=\"(color ?? '#').substring(1)\" (ngModelChange)=\"inputColor($event)\" #input />\n </div>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
294
+ }
295
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryColorPickerComponent, decorators: [{
296
+ type: Component,
297
+ args: [{ selector: 'pry-color-picker', providers: [
298
+ {
299
+ provide: NG_VALUE_ACCESSOR,
300
+ useExisting: forwardRef(() => PryColorPickerComponent),
301
+ multi: true
302
+ }
303
+ ], template: "<div\n class=\"a-color-picker\"\n (click)=\"togglePicker($event)\"\n [style.background-color]=\"temporaryColor ?? color\"\n [title]=\"color\"\n role=\"button\"\n>\n <div class=\"a-color-picker__modal\" [style.display]=\"picking ? 'flex' : 'none'\">\n <div class=\"a-color-picker__modal__backdrop\">\n <canvas\n #selector\n class=\"a-color-picker__modal__selector\"\n (mousemove)=\"mouseMove($event)\"\n (mouseup)=\"mouseUp($event)\"\n height=\"300\"\n width=\"300\"\n ></canvas>\n <canvas\n #bar\n class=\"a-color-picker__modal__bar\"\n (click)=\"selectColorFromBar($event)\"\n height=\"300\"\n width=\"40\"\n ></canvas>\n <div class=\"a-color-picker__modal__input\" (click)=\"clickInput($event)\">\n #<input [ngModel]=\"(color ?? '#').substring(1)\" (ngModelChange)=\"inputColor($event)\" #input />\n </div>\n </div>\n </div>\n</div>\n" }]
304
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { selector: [{
305
+ type: ViewChild,
306
+ args: ['selector']
307
+ }], bar: [{
308
+ type: ViewChild,
309
+ args: ['bar']
310
+ }], input: [{
311
+ type: ViewChild,
312
+ args: ['input']
313
+ }] } });
314
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/components/color-picker/color-picker.component.ts","../../../../../../projects/provoly/dashboard/components/color-picker/color-picker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAoC,SAAS,EAAc,UAAU,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC/G,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;;AAczE,MAAM,OAAO,uBAAuB;IAqBlC,YAAoB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QApB1C,aAAQ,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;QACzB,YAAO,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;QACxB,UAAK,GAAI,SAAS,CAAC;QACnB,aAAQ,GAAW,SAAS,CAAC;QAC7B,aAAQ,GAAG,KAAK,CAAC;QACjB,aAAQ,GAAG,IAAI,CAAC;QAChB,YAAO,GAAY,KAAK,CAAC;QAMzB,2BAAsB,GAAqB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAClD,sBAAiB,GAAG,CAAC,CAAC;QAGtB,gBAAW,GAAG,CAAC,CAAC;QAChB,gBAAW,GAAG,CAAC,CAAC;IAG6B,CAAC;IAE9C,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAED,4EAA4E;IAC5E,UAAU,CAAC,KAAa;QACtB,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAC1C,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1B,IAAI,CAAC,OAAO,EAAE,CAAC;YACf,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YACxB,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;SACxB;IACH,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,eAAe;QACb,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE,kBAAkB,EAAE,IAAI,EAAE,CAAE,CAAC;QACnG,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,UAAU,CAAC,IAAI,EAAE,EAAE,kBAAkB,EAAE,IAAI,EAAE,CAAE,CAAC;IAC3F,CAAC;IAED,YAAY,CAAC,MAAkB;QAC7B,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC;QAC/C,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,cAAc,EAAE;YACxC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACtC;QACD,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;IACH,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC5G,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,eAAe,EAAE,KAAK,EAAE,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;QAChF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,EAAE,CAAC,eAAe,EAAE,MAAM,CAAC,CAAC,CAAC;QAC9E,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,SAAS;QACP,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC7F,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE;YAC5C,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;YACT,SAAS;SACV,CAAC,CAAC;QACH,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,iBAAiB,CAAC,IAA8B,EAAE,QAAQ,GAAG,IAAI,EAAE,MAAgB;QACjF,MAAM,YAAY,GAAqC,QAAQ;YAC7D,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;YAC/B,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QACjC,IAAI,QAAQ,GAAG,IAAI,CAAC,oBAAoB,CAAC,GAAG,YAAY,CAAC,CAAC;QAC1D,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;YAC5B,QAAQ,CAAC,YAAY,CAAC,GAAG,GAAG,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAC7D,CAAC;IAED,kBAAkB;QAChB,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,oBAAoB,CACxD,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAC9B,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAC9B,IAAI,CAAC,WAAW,EAChB,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAC9B,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAC9B,IAAI,CAAC,WAAW,CACjB,CAAC;QACF,QAAQ,CAAC,YAAY,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC;QAC1C,QAAQ,CAAC,YAAY,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;QAEpC,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,CAAC;QACjC,IAAI,CAAC,eAAe,CAAC,GAAG,CACtB,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAC9B,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAC9B,IAAI,CAAC,WAAW,EAChB,CAAC,EACD,CAAC,GAAG,IAAI,CAAC,EAAE,CACZ,CAAC;QACF,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1C,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;QAC5B,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC;IAChC,CAAC;IAED,aAAa;QACX,IAAI,CAAC,UAAU,CAAC,WAAW,GAAG,iBAAiB,CAAC;QAChD,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;QAC5B,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC;QACrE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC;QAChG,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;QACzB,IAAI,CAAC,UAAU,CAAC,SAAS,EAAE,CAAC;QAC5B,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC;QACrE,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC;QAChG,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW,CAAC,MAAkB,EAAE,SAAS,GAAG,KAAK;QAC/C,mBAAmB;QACnB,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,CAC9B,GAAI,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAIhF,CACH,CAAC;QACF,IAAI,CAAC,SAAS,EAAE;YACd,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;SAC7B;aAAM;YACL,IAAI,CAAC,cAAc,GAAG,UAAU,CAAC;SAClC;QAED,IAAI,CAAC,sBAAsB,GAAG,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;QAC/D,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,MAAM,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,kBAAkB,CAAC,MAAkB;QACnC,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC,OAAO,CAAC;QACxC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAC3B,GAAI,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,EAAE,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAyC,CAC3G,CAAC;QACF,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,WAAW,CACd;YACE,OAAO,EAAE,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC;YACvC,OAAO,EAAE,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC;YACvC,eAAe,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,eAAe,EAAE;SACvB,EAC1B,IAAI,CACL,CAAC;QACF,MAAM,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,cAAc,CAAC,CAAS;QACtB,OAAO,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IACzC,CAAC;IAED,QAAQ,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS;QACtC,OAAO,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;IACxF,CAAC;IAED,UAAU,CAAC,MAAkB;QAC3B,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QACjC,MAAM,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,UAAU,CAAC,MAAW;QACpB,MAAM,aAAa,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;QAClG,IAAI,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE;YACzC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;YAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAM,CAAC,CAAC;YACzC,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YACnC,IAAI,CAAC,iBAAiB,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC;YACxE,IAAI,CAAC,sBAAsB,GAAG;gBAC5B,CAAC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG,GAAG;gBAClD,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC;aACxD,CAAC;YACF,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;YAC/C,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IAED,SAAS,CAAC,GAAW;QACnB,MAAM,KAAK,GAAG,uEAAuE,CAAC;QACtF,IAAI,KAAK,EAAE,IAAI,CAAC;QAEhB,6CAA6C;QAC7C,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,MAAM,CAAC;QAExC,2DAA2D;QAC3D,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,GAAG,CAAC;QACrC,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;QAEnD,IAAI,KAAK,EAAE;YACT,IAAI,GAAG;gBACL,aAAa;gBACb,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC;gBACf,aAAa;gBACb,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC;gBACf,aAAa;gBACb,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC;gBACf,aAAa;gBACb,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC;aAChB,CAAC;YAEF,qFAAqF;YACrF,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;SAC7B;aAAM;YACL,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS;iBACnC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC;iBAChB,KAAK,CAAC,OAAO,CAAE;iBACf,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;YAC/B,IAAI,GAAG;gBACL,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;gBACX,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;gBACX,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;gBACX,CAAC,EAAE,CAAC;aACL,CAAC;SACH;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,UAAU,CAAC,IAAS;QAClB,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC;QACzB,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC;QAC3B,MAAM,IAAI,GAAG,IAAI,CAAC,CAAC,GAAG,GAAG,CAAC;QAC1B,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QACxC,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QACxC,MAAM,MAAM,GAAG,IAAI,GAAG,IAAI,CAAC;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC;QACnB,IAAI,GAAG,GAAG,CAAC,CAAC;QACZ,IAAI,UAAU,GAAG,CAAC,CAAC;QAEnB,IAAI,MAAM,EAAE;YACV,IAAI,IAAI,KAAK,GAAG,EAAE;gBAChB,GAAG,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,GAAG,MAAM,CAAC;aAC/B;YACD,IAAI,IAAI,KAAK,KAAK,EAAE;gBAClB,GAAG,GAAG,CAAC,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,GAAG,MAAM,CAAC;aACjC;YACD,IAAI,IAAI,KAAK,IAAI,EAAE;gBACjB,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,KAAK,CAAC,GAAG,MAAM,CAAC;aAClC;YACD,IAAI,IAAI,EAAE;gBACR,UAAU,GAAG,MAAM,GAAG,IAAI,CAAC;aAC5B;SACF;QAED,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,EAAE,CAAC,CAAC;QAE3B,OAAO;YACL,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG;YAC5B,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,GAAG,CAAC;YAC/B,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC;YAC1B,CAAC,EAAE,IAAI,CAAC,CAAC;SACV,CAAC;IACJ,CAAC;IAED,QAAQ,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS;QACtC,CAAC,IAAI,GAAG,CAAC;QACT,CAAC,IAAI,GAAG,CAAC;QAET,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,EACnC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAC1C,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,EACb,CAAC,GAAG,CAAC,EACL,CAAC,GAAG,CAAC,EACL,CAAC,GAAG,CAAC,CAAC;QAER,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,EAAE;YACpB,CAAC,GAAG,CAAC,CAAC;YACN,CAAC,GAAG,CAAC,CAAC;YACN,CAAC,GAAG,CAAC,CAAC;SACP;aAAM,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,EAAE;YAC7B,CAAC,GAAG,CAAC,CAAC;YACN,CAAC,GAAG,CAAC,CAAC;YACN,CAAC,GAAG,CAAC,CAAC;SACP;aAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,EAAE;YAC9B,CAAC,GAAG,CAAC,CAAC;YACN,CAAC,GAAG,CAAC,CAAC;YACN,CAAC,GAAG,CAAC,CAAC;SACP;aAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,EAAE;YAC9B,CAAC,GAAG,CAAC,CAAC;YACN,CAAC,GAAG,CAAC,CAAC;YACN,CAAC,GAAG,CAAC,CAAC;SACP;aAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,EAAE;YAC9B,CAAC,GAAG,CAAC,CAAC;YACN,CAAC,GAAG,CAAC,CAAC;YACN,CAAC,GAAG,CAAC,CAAC;SACP;aAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,EAAE;YAC9B,CAAC,GAAG,CAAC,CAAC;YACN,CAAC,GAAG,CAAC,CAAC;YACN,CAAC,GAAG,CAAC,CAAC;SACP;QACD,+CAA+C;QAC/C,aAAa;QACb,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAC3C,aAAa;QACb,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAC3C,aAAa;QACb,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAE3C,2BAA2B;QAC3B,aAAa;QACb,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC;YAAE,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;QAC/B,aAAa;QACb,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC;YAAE,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;QAC/B,aAAa;QACb,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC;YAAE,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;QAE/B,OAAO,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACzB,CAAC;IAED,SAAS,CAAC,MAAkB;QAC1B,IAAI,MAAM,CAAC,OAAO,GAAG,CAAC,EAAE;YACtB,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;SAChC;IACH,CAAC;IAED,OAAO,CAAC,MAAkB;QACxB,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAClC,CAAC;8GAtVU,uBAAuB;kGAAvB,uBAAuB,2CARvB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,uBAAuB,CAAC;gBACtD,KAAK,EAAE,IAAI;aACZ;SACF,8RCbH,q8BA8BA;;2FDfa,uBAAuB;kBAZnC,SAAS;+BACE,kBAAkB,aAGjB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,wBAAwB,CAAC;4BACtD,KAAK,EAAE,IAAI;yBACZ;qBACF;wGAWsB,QAAQ;sBAA9B,SAAS;uBAAC,UAAU;gBAEH,GAAG;sBAApB,SAAS;uBAAC,KAAK;gBAKI,KAAK;sBAAxB,SAAS;uBAAC,OAAO","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, ElementRef, forwardRef, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'pry-color-picker',\n  templateUrl: './color-picker.component.html',\n\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PryColorPickerComponent),\n      multi: true\n    }\n  ]\n})\nexport class PryColorPickerComponent implements ControlValueAccessor, AfterViewInit {\n  onChange: any = () => {};\n  onTouch: any = () => {};\n  color? = '#000000';\n  barColor: string = '#0000ff';\n  disabled = false;\n  inhibate = true;\n  picking: boolean = false;\n\n  @ViewChild('selector') selector!: ElementRef<HTMLCanvasElement>;\n  selectorContext!: CanvasRenderingContext2D;\n  @ViewChild('bar') bar!: ElementRef<HTMLCanvasElement>;\n  barContext!: CanvasRenderingContext2D;\n  markerSelectorPosition: [number, number] = [0, 0];\n  markerBarPosition = 0;\n\n  @ViewChild('input') input!: ElementRef<HTMLInputElement>;\n  innerRadius = 3;\n  outerRadius = 8;\n  temporaryColor?: string;\n\n  constructor(private _cd: ChangeDetectorRef) {}\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  // Define what should happen in this component, if something changes outside\n  writeValue(color: string) {\n    if (this.color !== color && !this.inhibate) {\n      this.color = color;\n      this.onChange(this.color);\n      this.onTouch();\n      this._cd.markForCheck();\n      this.inputColor(color);\n    }\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n    this._cd.markForCheck();\n  }\n\n  ngAfterViewInit(): void {\n    this.inhibate = false;\n    this.selectorContext = this.selector.nativeElement.getContext('2d', { willReadFrequently: true })!;\n    this.barContext = this.bar.nativeElement.getContext('2d', { willReadFrequently: true })!;\n  }\n\n  togglePicker($event: MouseEvent) {\n    this.picking = !this.disabled && !this.picking;\n    if (!this.picking && this.temporaryColor) {\n      this.writeValue(this.temporaryColor);\n    }\n    if (this.picking) {\n      this.redrawSelector();\n      this.redrawBar();\n    }\n  }\n\n  redrawSelector() {\n    this.selectorContext.clearRect(0, 0, this.selectorContext.canvas.width, this.selectorContext.canvas.height);\n    this.drawColorGradient(this.selectorContext, false, ['#ffffff', this.barColor]);\n    this.drawColorGradient(this.selectorContext, true, ['rgba(0,0,0,0)', '#000']);\n    this.drawSelectorMarker();\n  }\n\n  redrawBar() {\n    this.barContext.clearRect(0, 0, this.barContext.canvas.width, this.barContext.canvas.height);\n    this.drawColorGradient(this.barContext, true, [\n      '#FF0000',\n      '#ffff00',\n      '#00FF00',\n      '#00FFFF',\n      '#0000FF',\n      '#FF00FF',\n      '#FF0000'\n    ]);\n    this.drawBarMarker();\n  }\n\n  drawColorGradient(ctxt: CanvasRenderingContext2D, vertical = true, colors: string[]) {\n    const gradientArgs: [number, number, number, number] = vertical\n      ? [0, 0, 0, ctxt.canvas.height]\n      : [0, 0, ctxt.canvas.width, 0];\n    let gradient = ctxt.createLinearGradient(...gradientArgs);\n    colors.forEach((color, idx) => {\n      gradient.addColorStop(idx / (colors.length - 1), color);\n    });\n    ctxt.fillStyle = gradient;\n    ctxt.fillRect(0, 0, ctxt.canvas.width, ctxt.canvas.height);\n  }\n\n  drawSelectorMarker() {\n    const gradient = this.selectorContext.createRadialGradient(\n      this.markerSelectorPosition[0],\n      this.markerSelectorPosition[1],\n      this.innerRadius,\n      this.markerSelectorPosition[0],\n      this.markerSelectorPosition[1],\n      this.outerRadius\n    );\n    gradient.addColorStop(0, 'rgba(0,0,0,0)');\n    gradient.addColorStop(1, '#ffffff');\n\n    this.selectorContext.beginPath();\n    this.selectorContext.arc(\n      this.markerSelectorPosition[0],\n      this.markerSelectorPosition[1],\n      this.outerRadius,\n      0,\n      2 * Math.PI\n    );\n    this.selectorContext.fillStyle = gradient;\n    this.selectorContext.fill();\n    this.selectorContext.stroke();\n  }\n\n  drawBarMarker() {\n    this.barContext.strokeStyle = '2px solid black';\n    this.barContext.beginPath();\n    this.barContext.moveTo(0, this.markerBarPosition - this.innerRadius);\n    this.barContext.lineTo(this.barContext.canvas.width, this.markerBarPosition - this.innerRadius);\n    this.barContext.stroke();\n    this.barContext.beginPath();\n    this.barContext.moveTo(0, this.markerBarPosition + this.innerRadius);\n    this.barContext.lineTo(this.barContext.canvas.width, this.markerBarPosition + this.innerRadius);\n    this.barContext.stroke();\n  }\n\n  selectColor($event: MouseEvent, temporary = false) {\n    // Read pixel Color\n    const pixelColor = this.rgbToHex(\n      ...(this.selectorContext.getImageData($event.offsetX, $event.offsetY, 1, 1)['data'] as unknown as [\n        number,\n        number,\n        number\n      ])\n    );\n    if (!temporary) {\n      this.writeValue(pixelColor);\n    } else {\n      this.temporaryColor = pixelColor;\n    }\n\n    this.markerSelectorPosition = [$event.offsetX, $event.offsetY];\n    this.redrawSelector();\n    $event.stopPropagation();\n  }\n\n  selectColorFromBar($event: MouseEvent) {\n    this.markerBarPosition = $event.offsetY;\n    this.barColor = this.rgbToHex(\n      ...(this.barContext.getImageData(20, $event.offsetY, 1, 1)['data'] as unknown as [number, number, number])\n    );\n    this.redrawBar();\n    this.redrawSelector();\n    this.selectColor(\n      {\n        offsetX: this.markerSelectorPosition[0],\n        offsetY: this.markerSelectorPosition[1],\n        stopPropagation: () => $event.stopPropagation()\n      } as unknown as MouseEvent,\n      true\n    );\n    $event.stopPropagation();\n  }\n\n  componentToHex(c: number) {\n    return c.toString(16).padStart(2, '0');\n  }\n\n  rgbToHex(r: number, g: number, b: number) {\n    return '#' + this.componentToHex(r) + this.componentToHex(g) + this.componentToHex(b);\n  }\n\n  clickInput($event: MouseEvent) {\n    this.input.nativeElement.focus();\n    $event.stopPropagation();\n  }\n\n  inputColor($event: any) {\n    const possibleColor = !!$event ? ($event.indexOf('#') === -1 ? '#' + $event : $event) : '#FFFFFF';\n    if (/^#[0-9A-F]{6}$/i.test(possibleColor)) {\n      this.writeValue(possibleColor);\n      const rgba = this.strToRGBA(this.color!);\n      const hsva = this.RGBAtoHSVA(rgba);\n      this.markerBarPosition = (this.barContext.canvas.height * hsva.h) / 360;\n      this.markerSelectorPosition = [\n        (this.selectorContext.canvas.width * hsva.s) / 100,\n        this.selectorContext.canvas.height * (1 - hsva.v / 100)\n      ];\n      this.barColor = this.hslToHex(hsva.h, 100, 50);\n      this.redrawBar();\n      this.redrawSelector();\n    }\n  }\n\n  strToRGBA(str: string) {\n    const regex = /^((rgba)|rgb)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]+([\\d.]+)[\\D]*?([\\d.]+|$)/i;\n    let match, rgba;\n\n    // Default to black for invalid color strings\n    this.selectorContext.fillStyle = '#000';\n\n    // Use canvas to convert the string to a valid color string\n    this.selectorContext.fillStyle = str;\n    match = regex.exec(this.selectorContext.fillStyle);\n\n    if (match) {\n      rgba = {\n        // @ts-ignore\n        r: match[3] * 1,\n        // @ts-ignore\n        g: match[4] * 1,\n        // @ts-ignore\n        b: match[5] * 1,\n        // @ts-ignore\n        a: match[6] * 1\n      };\n\n      // Workaround to mitigate a Chromium bug where the alpha value is rounded incorrectly\n      rgba.a = +rgba.a.toFixed(2);\n    } else {\n      match = this.selectorContext.fillStyle\n        .replace('#', '')\n        .match(/.{2}/g)!\n        .map((h) => parseInt(h, 16));\n      rgba = {\n        r: match[0],\n        g: match[1],\n        b: match[2],\n        a: 1\n      };\n    }\n\n    return rgba;\n  }\n\n  RGBAtoHSVA(rgba: any) {\n    const red = rgba.r / 255;\n    const green = rgba.g / 255;\n    const blue = rgba.b / 255;\n    const xmax = Math.max(red, green, blue);\n    const xmin = Math.min(red, green, blue);\n    const chroma = xmax - xmin;\n    const value = xmax;\n    let hue = 0;\n    let saturation = 0;\n\n    if (chroma) {\n      if (xmax === red) {\n        hue = (green - blue) / chroma;\n      }\n      if (xmax === green) {\n        hue = 2 + (blue - red) / chroma;\n      }\n      if (xmax === blue) {\n        hue = 4 + (red - green) / chroma;\n      }\n      if (xmax) {\n        saturation = chroma / xmax;\n      }\n    }\n\n    hue = Math.floor(hue * 60);\n\n    return {\n      h: hue < 0 ? hue + 360 : hue,\n      s: Math.round(saturation * 100),\n      v: Math.round(value * 100),\n      a: rgba.a\n    };\n  }\n\n  hslToHex(h: number, s: number, l: number) {\n    s /= 100;\n    l /= 100;\n\n    let c = (1 - Math.abs(2 * l - 1)) * s,\n      x = c * (1 - Math.abs(((h / 60) % 2) - 1)),\n      m = l - c / 2,\n      r = 0,\n      g = 0,\n      b = 0;\n\n    if (0 <= h && h < 60) {\n      r = c;\n      g = x;\n      b = 0;\n    } else if (60 <= h && h < 120) {\n      r = x;\n      g = c;\n      b = 0;\n    } else if (120 <= h && h < 180) {\n      r = 0;\n      g = c;\n      b = x;\n    } else if (180 <= h && h < 240) {\n      r = 0;\n      g = x;\n      b = c;\n    } else if (240 <= h && h < 300) {\n      r = x;\n      g = 0;\n      b = c;\n    } else if (300 <= h && h < 360) {\n      r = c;\n      g = 0;\n      b = x;\n    }\n    // Having obtained RGB, convert channels to hex\n    // @ts-ignore\n    r = Math.round((r + m) * 255).toString(16);\n    // @ts-ignore\n    g = Math.round((g + m) * 255).toString(16);\n    // @ts-ignore\n    b = Math.round((b + m) * 255).toString(16);\n\n    // Prepend 0s, if necessary\n    // @ts-ignore\n    if (r.length == 1) r = '0' + r;\n    // @ts-ignore\n    if (g.length == 1) g = '0' + g;\n    // @ts-ignore\n    if (b.length == 1) b = '0' + b;\n\n    return '#' + r + g + b;\n  }\n\n  mouseMove($event: MouseEvent) {\n    if ($event.buttons > 0) {\n      this.selectColor($event, true);\n    }\n  }\n\n  mouseUp($event: MouseEvent) {\n    this.selectColor($event, false);\n  }\n}\n","<div\n  class=\"a-color-picker\"\n  (click)=\"togglePicker($event)\"\n  [style.background-color]=\"temporaryColor ?? color\"\n  [title]=\"color\"\n  role=\"button\"\n>\n  <div class=\"a-color-picker__modal\" [style.display]=\"picking ? 'flex' : 'none'\">\n    <div class=\"a-color-picker__modal__backdrop\">\n      <canvas\n        #selector\n        class=\"a-color-picker__modal__selector\"\n        (mousemove)=\"mouseMove($event)\"\n        (mouseup)=\"mouseUp($event)\"\n        height=\"300\"\n        width=\"300\"\n      ></canvas>\n      <canvas\n        #bar\n        class=\"a-color-picker__modal__bar\"\n        (click)=\"selectColorFromBar($event)\"\n        height=\"300\"\n        width=\"40\"\n      ></canvas>\n      <div class=\"a-color-picker__modal__input\" (click)=\"clickInput($event)\">\n        #<input [ngModel]=\"(color ?? '#').substring(1)\" (ngModelChange)=\"inputColor($event)\" #input />\n      </div>\n    </div>\n  </div>\n</div>\n"]}
@@ -0,0 +1,20 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { PryColorPickerComponent } from './color-picker.component';
5
+ import * as i0 from "@angular/core";
6
+ const PRY_COLORPICKER_COMPONENTS = [PryColorPickerComponent];
7
+ export class PryColorPickerModule {
8
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryColorPickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
9
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.6", ngImport: i0, type: PryColorPickerModule, declarations: [PryColorPickerComponent], imports: [CommonModule, FormsModule], exports: [PryColorPickerComponent] }); }
10
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryColorPickerModule, imports: [CommonModule, FormsModule] }); }
11
+ }
12
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryColorPickerModule, decorators: [{
13
+ type: NgModule,
14
+ args: [{
15
+ imports: [CommonModule, FormsModule],
16
+ declarations: [...PRY_COLORPICKER_COMPONENTS],
17
+ exports: [...PRY_COLORPICKER_COMPONENTS]
18
+ }]
19
+ }] });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3ItcGlja2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2NvbXBvbmVudHMvY29sb3ItcGlja2VyL2NvbG9yLXBpY2tlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDOztBQUVuRSxNQUFNLDBCQUEwQixHQUFHLENBQUMsdUJBQXVCLENBQUMsQ0FBQztBQU83RCxNQUFNLE9BQU8sb0JBQW9COzhHQUFwQixvQkFBb0I7K0dBQXBCLG9CQUFvQixpQkFQRyx1QkFBdUIsYUFHL0MsWUFBWSxFQUFFLFdBQVcsYUFIRCx1QkFBdUI7K0dBTzlDLG9CQUFvQixZQUpyQixZQUFZLEVBQUUsV0FBVzs7MkZBSXhCLG9CQUFvQjtrQkFMaEMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsV0FBVyxDQUFDO29CQUNwQyxZQUFZLEVBQUUsQ0FBQyxHQUFHLDBCQUEwQixDQUFDO29CQUM3QyxPQUFPLEVBQUUsQ0FBQyxHQUFHLDBCQUEwQixDQUFDO2lCQUN6QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBQcnlDb2xvclBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vY29sb3ItcGlja2VyLmNvbXBvbmVudCc7XG5cbmNvbnN0IFBSWV9DT0xPUlBJQ0tFUl9DT01QT05FTlRTID0gW1ByeUNvbG9yUGlja2VyQ29tcG9uZW50XTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFsuLi5QUllfQ09MT1JQSUNLRVJfQ09NUE9ORU5UU10sXG4gIGV4cG9ydHM6IFsuLi5QUllfQ09MT1JQSUNLRVJfQ09NUE9ORU5UU11cbn0pXG5leHBvcnQgY2xhc3MgUHJ5Q29sb3JQaWNrZXJNb2R1bGUge31cbiJdfQ==
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdm9seS1kYXNoYm9hcmQtY29tcG9uZW50cy1jb2xvci1waWNrZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9jb21wb25lbnRzL2NvbG9yLXBpY2tlci9wcm92b2x5LWRhc2hib2FyZC1jb21wb25lbnRzLWNvbG9yLXBpY2tlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
@@ -0,0 +1,3 @@
1
+ export * from './color-picker.module';
2
+ export * from './color-picker.component';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2NvbXBvbmVudHMvY29sb3ItcGlja2VyL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb2xvci1waWNrZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vY29sb3ItcGlja2VyLmNvbXBvbmVudCc7XG4iXX0=
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdm9seS1kYXNoYm9hcmQtY29tcG9uZW50cy1zY2hlbWUtcGlja2VyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvY29tcG9uZW50cy9zY2hlbWUtcGlja2VyL3Byb3ZvbHktZGFzaGJvYXJkLWNvbXBvbmVudHMtc2NoZW1lLXBpY2tlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
@@ -0,0 +1,4 @@
1
+ export * from './scheme-picker.module';
2
+ export * from './scheme-picker.component';
3
+ export * from './scheme.service';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2NvbXBvbmVudHMvc2NoZW1lLXBpY2tlci9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGtCQUFrQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zY2hlbWUtcGlja2VyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3NjaGVtZS1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2NoZW1lLnNlcnZpY2UnO1xuIl19
@@ -0,0 +1,104 @@
1
+ import { Component, forwardRef } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { BehaviorSubject, map } from 'rxjs';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "./scheme.service";
6
+ import * as i2 from "@provoly/dashboard";
7
+ import * as i3 from "@angular/common";
8
+ import * as i4 from "@angular/forms";
9
+ import * as i5 from "@provoly/dashboard/components/color-picker";
10
+ export class PrySchemePickerComponent {
11
+ constructor(_cd, schemeService, i18nService) {
12
+ this._cd = _cd;
13
+ this.schemeService = schemeService;
14
+ this.i18nService = i18nService;
15
+ this.onChange = () => { };
16
+ this.onTouch = () => { };
17
+ this.scheme$ = new BehaviorSubject('Provoly');
18
+ this.inhibate = true;
19
+ this.disabled = false;
20
+ this.schemes$ = this.schemeService.schemeIds$.pipe(map((schemes) => {
21
+ let customNumber = 1;
22
+ return schemes.map((scheme, idx) => ({
23
+ id: scheme,
24
+ label: scheme.indexOf('#') === 0 ? this.i18nService.instant('@pry.widget.custom', { id: customNumber++ }) : scheme
25
+ }));
26
+ }));
27
+ this.schemeColors$ = this.scheme$.pipe(map((scheme) => this.schemeService.getSchemeColors(scheme)));
28
+ }
29
+ registerOnChange(fn) {
30
+ this.onChange = fn;
31
+ }
32
+ registerOnTouched(fn) {
33
+ this.onTouch = fn;
34
+ }
35
+ // Define what should happen in this component, if something changes outside
36
+ writeValue(scheme) {
37
+ if (this.scheme$.getValue() !== scheme && !this.inhibate) {
38
+ this.scheme$.next(scheme);
39
+ this.onChange(this.scheme$.getValue());
40
+ this.onTouch();
41
+ this._cd.markForCheck();
42
+ this.schemeService.assertScheme(this.scheme$.getValue());
43
+ this.temporaryDisable();
44
+ }
45
+ }
46
+ setDisabledState(isDisabled) {
47
+ this.disabled = isDisabled;
48
+ this._cd.markForCheck();
49
+ }
50
+ temporaryDisable() {
51
+ this.inhibate = true;
52
+ setTimeout(() => {
53
+ this.inhibate = false;
54
+ }, 100);
55
+ }
56
+ ngAfterViewInit() {
57
+ this.temporaryDisable();
58
+ }
59
+ changeColorScheme($event) {
60
+ if ($event === '#') {
61
+ this.writeValue(this.schemeService.getSchemeColors(this.schemeService.getDefaultScheme()).join(','));
62
+ }
63
+ else {
64
+ this.writeValue($event);
65
+ }
66
+ }
67
+ modifyColorScheme($event, index) {
68
+ if (!this.inhibate) {
69
+ const newScheme = [...this.schemeService.getSchemeColors(this.scheme$.getValue())];
70
+ newScheme[index] = $event;
71
+ this.writeValue(newScheme.join(','));
72
+ }
73
+ }
74
+ addColorToScheme() {
75
+ this.writeValue(this.schemeService
76
+ .getSchemeColors(this.scheme$.getValue())
77
+ .concat('#' + this.schemeService.randomColor())
78
+ .join(','));
79
+ }
80
+ removeColorFromScheme(index) {
81
+ const newScheme = [...this.schemeService.getSchemeColors(this.scheme$.getValue())];
82
+ newScheme.splice(index, 1);
83
+ this.writeValue(newScheme.join(','));
84
+ }
85
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PrySchemePickerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.PrySchemeService }, { token: i2.PryI18nService }], target: i0.ɵɵFactoryTarget.Component }); }
86
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PrySchemePickerComponent, selector: "pry-scheme-picker", providers: [
87
+ {
88
+ provide: NG_VALUE_ACCESSOR,
89
+ useExisting: forwardRef(() => PrySchemePickerComponent),
90
+ multi: true
91
+ }
92
+ ], ngImport: i0, template: "<div class=\"m-color-scheme\">\n <label class=\"a-label\" for=\"scheme\">{{ '@pry.widget.colorScheme' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"changeColorScheme($event)\"\n [ngModel]=\"scheme$ | async\"\n [itemsAsOption]=\"true\"\n [items]=\"schemes$ | async\"\n id=\"scheme\"\n bindValue=\"id\"\n bindLabel=\"label\"\n ></pry-select>\n</div>\n\n<div class=\"m-color-scheme__display\">\n <div class=\"m-color-scheme__display__item\" *ngFor=\"let colorScheme of schemeColors$ | async; let i = index\">\n <pry-color-picker [ngModel]=\"colorScheme\" (ngModelChange)=\"modifyColorScheme($event, i)\"></pry-color-picker>\n <button\n (click)=\"removeColorFromScheme(i)\"\n class=\"a-btn a-btn--icon-only\"\n title=\"{{ '@pry.widget.removeColor' | i18n }}\"\n >\n <span class=\"u-visually-hidden\">{{ '@pry.widget.removeColor' | i18n }}</span>\n <pry-icon iconSvg=\"trash\"></pry-icon>\n </button>\n </div>\n <button\n (click)=\"addColorToScheme()\"\n class=\"a-btn a-btn--primary a-btn--icon-only\"\n title=\"{{ '@pry.widget.addColor' | i18n }}\"\n >\n <span class=\"u-visually-hidden\">{{ '@pry.widget.addColor' | i18n }}</span>\n <pry-icon iconSvg=\"add\"></pry-icon>\n </button>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.PrySelectComponent, selector: "pry-select", inputs: ["labelTranslate", "baseTranslate", "translationFn", "translationFnArgs", "clearable", "multiple", "multipleClearRight", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "items", "itemsAsOption", "bindData", "bindValue", "bindLabel", "bindIcon", "iconSize", "templateLabel", "templateOption", "autocomplete"] }, { kind: "component", type: i5.PryColorPickerComponent, selector: "pry-color-picker" }, { kind: "component", type: i2.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.I18nPipe, name: "i18n" }] }); }
93
+ }
94
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PrySchemePickerComponent, decorators: [{
95
+ type: Component,
96
+ args: [{ selector: 'pry-scheme-picker', providers: [
97
+ {
98
+ provide: NG_VALUE_ACCESSOR,
99
+ useExisting: forwardRef(() => PrySchemePickerComponent),
100
+ multi: true
101
+ }
102
+ ], template: "<div class=\"m-color-scheme\">\n <label class=\"a-label\" for=\"scheme\">{{ '@pry.widget.colorScheme' | i18n }}</label>\n <pry-select\n (ngModelChange)=\"changeColorScheme($event)\"\n [ngModel]=\"scheme$ | async\"\n [itemsAsOption]=\"true\"\n [items]=\"schemes$ | async\"\n id=\"scheme\"\n bindValue=\"id\"\n bindLabel=\"label\"\n ></pry-select>\n</div>\n\n<div class=\"m-color-scheme__display\">\n <div class=\"m-color-scheme__display__item\" *ngFor=\"let colorScheme of schemeColors$ | async; let i = index\">\n <pry-color-picker [ngModel]=\"colorScheme\" (ngModelChange)=\"modifyColorScheme($event, i)\"></pry-color-picker>\n <button\n (click)=\"removeColorFromScheme(i)\"\n class=\"a-btn a-btn--icon-only\"\n title=\"{{ '@pry.widget.removeColor' | i18n }}\"\n >\n <span class=\"u-visually-hidden\">{{ '@pry.widget.removeColor' | i18n }}</span>\n <pry-icon iconSvg=\"trash\"></pry-icon>\n </button>\n </div>\n <button\n (click)=\"addColorToScheme()\"\n class=\"a-btn a-btn--primary a-btn--icon-only\"\n title=\"{{ '@pry.widget.addColor' | i18n }}\"\n >\n <span class=\"u-visually-hidden\">{{ '@pry.widget.addColor' | i18n }}</span>\n <pry-icon iconSvg=\"add\"></pry-icon>\n </button>\n</div>\n" }]
103
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.PrySchemeService }, { type: i2.PryI18nService }]; } });
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scheme-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/components/scheme-picker/scheme-picker.component.ts","../../../../../../projects/provoly/dashboard/components/scheme-picker/scheme-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { PrySchemeService } from './scheme.service';\nimport { BehaviorSubject, map, Observable } from 'rxjs';\nimport { PryI18nService } from '@provoly/dashboard';\n\n@Component({\n  selector: 'pry-scheme-picker',\n  templateUrl: './scheme-picker.component.html',\n\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => PrySchemePickerComponent),\n      multi: true\n    }\n  ]\n})\nexport class PrySchemePickerComponent implements ControlValueAccessor, AfterViewInit {\n  onChange: any = () => {};\n  onTouch: any = () => {};\n  scheme$ = new BehaviorSubject<string>('Provoly');\n  schemes$: Observable<{ id: string; label: string }[]>;\n  inhibate = true;\n  disabled = false;\n  schemeColors$: Observable<string[]>;\n\n  constructor(\n    private _cd: ChangeDetectorRef,\n    private schemeService: PrySchemeService,\n    private i18nService: PryI18nService\n  ) {\n    this.schemes$ = this.schemeService.schemeIds$.pipe(\n      map((schemes) => {\n        let customNumber = 1;\n        return schemes.map((scheme, idx) => ({\n          id: scheme,\n          label:\n            scheme.indexOf('#') === 0 ? this.i18nService.instant('@pry.widget.custom', { id: customNumber++ }) : scheme\n        }));\n      })\n    );\n    this.schemeColors$ = this.scheme$.pipe(map((scheme) => this.schemeService.getSchemeColors(scheme)));\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n\n  // Define what should happen in this component, if something changes outside\n  writeValue(scheme: string) {\n    if (this.scheme$.getValue() !== scheme && !this.inhibate) {\n      this.scheme$.next(scheme);\n      this.onChange(this.scheme$.getValue());\n      this.onTouch();\n      this._cd.markForCheck();\n      this.schemeService.assertScheme(this.scheme$.getValue());\n      this.temporaryDisable();\n    }\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n    this._cd.markForCheck();\n  }\n\n  temporaryDisable() {\n    this.inhibate = true;\n    setTimeout(() => {\n      this.inhibate = false;\n    }, 100);\n  }\n\n  ngAfterViewInit(): void {\n    this.temporaryDisable();\n  }\n\n  changeColorScheme($event: any) {\n    if ($event === '#') {\n      this.writeValue(this.schemeService.getSchemeColors(this.schemeService.getDefaultScheme()).join(','));\n    } else {\n      this.writeValue($event);\n    }\n  }\n\n  modifyColorScheme($event: string, index: number) {\n    if (!this.inhibate) {\n      const newScheme = [...this.schemeService.getSchemeColors(this.scheme$.getValue())];\n      newScheme[index] = $event;\n      this.writeValue(newScheme.join(','));\n    }\n  }\n\n  addColorToScheme() {\n    this.writeValue(\n      this.schemeService\n        .getSchemeColors(this.scheme$.getValue())\n        .concat('#' + this.schemeService.randomColor())\n        .join(',')\n    );\n  }\n\n  removeColorFromScheme(index: number) {\n    const newScheme = [...this.schemeService.getSchemeColors(this.scheme$.getValue())];\n    newScheme.splice(index, 1);\n    this.writeValue(newScheme.join(','));\n  }\n}\n","<div class=\"m-color-scheme\">\n  <label class=\"a-label\" for=\"scheme\">{{ '@pry.widget.colorScheme' | i18n }}</label>\n  <pry-select\n    (ngModelChange)=\"changeColorScheme($event)\"\n    [ngModel]=\"scheme$ | async\"\n    [itemsAsOption]=\"true\"\n    [items]=\"schemes$ | async\"\n    id=\"scheme\"\n    bindValue=\"id\"\n    bindLabel=\"label\"\n  ></pry-select>\n</div>\n\n<div class=\"m-color-scheme__display\">\n  <div class=\"m-color-scheme__display__item\" *ngFor=\"let colorScheme of schemeColors$ | async; let i = index\">\n    <pry-color-picker [ngModel]=\"colorScheme\" (ngModelChange)=\"modifyColorScheme($event, i)\"></pry-color-picker>\n    <button\n      (click)=\"removeColorFromScheme(i)\"\n      class=\"a-btn a-btn--icon-only\"\n      title=\"{{ '@pry.widget.removeColor' | i18n }}\"\n    >\n      <span class=\"u-visually-hidden\">{{ '@pry.widget.removeColor' | i18n }}</span>\n      <pry-icon iconSvg=\"trash\"></pry-icon>\n    </button>\n  </div>\n  <button\n    (click)=\"addColorToScheme()\"\n    class=\"a-btn a-btn--primary a-btn--icon-only\"\n    title=\"{{ '@pry.widget.addColor' | i18n }}\"\n  >\n    <span class=\"u-visually-hidden\">{{ '@pry.widget.addColor' | i18n }}</span>\n    <pry-icon iconSvg=\"add\"></pry-icon>\n  </button>\n</div>\n"]}
@@ -0,0 +1,22 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { PrySchemePickerComponent } from './scheme-picker.component';
5
+ import { PryI18nModule, PryIconModule, PrySelectModule } from '@provoly/dashboard';
6
+ import { PryColorPickerModule } from '@provoly/dashboard/components/color-picker';
7
+ import * as i0 from "@angular/core";
8
+ const PRY_SCHEMEPICKER_COMPONENTS = [PrySchemePickerComponent];
9
+ export class PrySchemePickerModule {
10
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PrySchemePickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
11
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.6", ngImport: i0, type: PrySchemePickerModule, declarations: [PrySchemePickerComponent], imports: [CommonModule, FormsModule, PryI18nModule, PrySelectModule, PryColorPickerModule, PryIconModule], exports: [PrySchemePickerComponent] }); }
12
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PrySchemePickerModule, imports: [CommonModule, FormsModule, PryI18nModule, PrySelectModule, PryColorPickerModule, PryIconModule] }); }
13
+ }
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PrySchemePickerModule, decorators: [{
15
+ type: NgModule,
16
+ args: [{
17
+ imports: [CommonModule, FormsModule, PryI18nModule, PrySelectModule, PryColorPickerModule, PryIconModule],
18
+ declarations: [...PRY_SCHEMEPICKER_COMPONENTS],
19
+ exports: [...PRY_SCHEMEPICKER_COMPONENTS]
20
+ }]
21
+ }] });
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NoZW1lLXBpY2tlci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9jb21wb25lbnRzL3NjaGVtZS1waWNrZXIvc2NoZW1lLXBpY2tlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3JFLE9BQU8sRUFBRSxhQUFhLEVBQUUsYUFBYSxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ25GLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDRDQUE0QyxDQUFDOztBQUVsRixNQUFNLDJCQUEyQixHQUFHLENBQUMsd0JBQXdCLENBQUMsQ0FBQztBQU8vRCxNQUFNLE9BQU8scUJBQXFCOzhHQUFyQixxQkFBcUI7K0dBQXJCLHFCQUFxQixpQkFQRyx3QkFBd0IsYUFHakQsWUFBWSxFQUFFLFdBQVcsRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLG9CQUFvQixFQUFFLGFBQWEsYUFIckUsd0JBQXdCOytHQU9oRCxxQkFBcUIsWUFKdEIsWUFBWSxFQUFFLFdBQVcsRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLG9CQUFvQixFQUFFLGFBQWE7OzJGQUk3RixxQkFBcUI7a0JBTGpDLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLG9CQUFvQixFQUFFLGFBQWEsQ0FBQztvQkFDekcsWUFBWSxFQUFFLENBQUMsR0FBRywyQkFBMkIsQ0FBQztvQkFDOUMsT0FBTyxFQUFFLENBQUMsR0FBRywyQkFBMkIsQ0FBQztpQkFDMUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgUHJ5U2NoZW1lUGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi9zY2hlbWUtcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQcnlJMThuTW9kdWxlLCBQcnlJY29uTW9kdWxlLCBQcnlTZWxlY3RNb2R1bGUgfSBmcm9tICdAcHJvdm9seS9kYXNoYm9hcmQnO1xuaW1wb3J0IHsgUHJ5Q29sb3JQaWNrZXJNb2R1bGUgfSBmcm9tICdAcHJvdm9seS9kYXNoYm9hcmQvY29tcG9uZW50cy9jb2xvci1waWNrZXInO1xuXG5jb25zdCBQUllfU0NIRU1FUElDS0VSX0NPTVBPTkVOVFMgPSBbUHJ5U2NoZW1lUGlja2VyQ29tcG9uZW50XTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIFByeUkxOG5Nb2R1bGUsIFByeVNlbGVjdE1vZHVsZSwgUHJ5Q29sb3JQaWNrZXJNb2R1bGUsIFByeUljb25Nb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFsuLi5QUllfU0NIRU1FUElDS0VSX0NPTVBPTkVOVFNdLFxuICBleHBvcnRzOiBbLi4uUFJZX1NDSEVNRVBJQ0tFUl9DT01QT05FTlRTXVxufSlcbmV4cG9ydCBjbGFzcyBQcnlTY2hlbWVQaWNrZXJNb2R1bGUge31cbiJdfQ==