@skyux/colorpicker 5.7.2 → 6.0.0-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/documentation.json +2 -2
- package/esm2020/index.mjs +16 -0
- package/esm2020/lib/modules/colorpicker/colorpicker-classes.mjs +24 -0
- package/esm2020/lib/modules/colorpicker/colorpicker-input.directive.mjs +264 -0
- package/esm2020/lib/modules/colorpicker/colorpicker-slider.directive.mjs +98 -0
- package/esm2020/lib/modules/colorpicker/colorpicker-text.directive.mjs +51 -0
- package/esm2020/lib/modules/colorpicker/colorpicker.component.mjs +413 -0
- package/esm2020/lib/modules/colorpicker/colorpicker.module.mjs +60 -0
- package/esm2020/lib/modules/colorpicker/colorpicker.service.mjs +342 -0
- package/esm2020/lib/modules/colorpicker/types/colorpicker-axis.mjs +2 -0
- package/esm2020/lib/modules/colorpicker/types/colorpicker-cmyk.mjs +2 -0
- package/esm2020/lib/modules/colorpicker/types/colorpicker-color.mjs +2 -0
- package/esm2020/lib/modules/colorpicker/types/colorpicker-hsla.mjs +2 -0
- package/esm2020/lib/modules/colorpicker/types/colorpicker-hsva.mjs +2 -0
- package/esm2020/lib/modules/colorpicker/types/colorpicker-message-type.mjs +23 -0
- package/esm2020/lib/modules/colorpicker/types/colorpicker-message.mjs +2 -0
- package/esm2020/lib/modules/colorpicker/types/colorpicker-output.mjs +2 -0
- package/esm2020/lib/modules/colorpicker/types/colorpicker-result.mjs +2 -0
- package/esm2020/lib/modules/colorpicker/types/colorpicker-rgba.mjs +2 -0
- package/esm2020/lib/modules/shared/sky-colorpicker-resources.module.mjs +64 -0
- package/esm2020/skyux-colorpicker.mjs +5 -0
- package/esm2020/testing/colorpicker-fixture.mjs +85 -0
- package/esm2020/testing/public-api.mjs +2 -0
- package/esm2020/testing/skyux-colorpicker-testing.mjs +5 -0
- package/fesm2015/{skyux-colorpicker-testing.js → skyux-colorpicker-testing.mjs} +1 -1
- package/fesm2015/skyux-colorpicker-testing.mjs.map +1 -0
- package/fesm2015/skyux-colorpicker.mjs +1319 -0
- package/fesm2015/skyux-colorpicker.mjs.map +1 -0
- package/fesm2020/skyux-colorpicker-testing.mjs +92 -0
- package/fesm2020/skyux-colorpicker-testing.mjs.map +1 -0
- package/fesm2020/skyux-colorpicker.mjs +1315 -0
- package/fesm2020/skyux-colorpicker.mjs.map +1 -0
- package/package.json +41 -17
- package/testing/package.json +5 -5
- package/bundles/skyux-colorpicker-testing.umd.js +0 -465
- package/bundles/skyux-colorpicker.umd.js +0 -1420
- package/esm2015/index.js +0 -16
- package/esm2015/index.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/colorpicker-classes.js +0 -24
- package/esm2015/lib/modules/colorpicker/colorpicker-classes.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/colorpicker-input.directive.js +0 -264
- package/esm2015/lib/modules/colorpicker/colorpicker-input.directive.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/colorpicker-slider.directive.js +0 -98
- package/esm2015/lib/modules/colorpicker/colorpicker-slider.directive.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/colorpicker-text.directive.js +0 -51
- package/esm2015/lib/modules/colorpicker/colorpicker-text.directive.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/colorpicker.component.js +0 -421
- package/esm2015/lib/modules/colorpicker/colorpicker.component.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/colorpicker.module.js +0 -61
- package/esm2015/lib/modules/colorpicker/colorpicker.module.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/colorpicker.service.js +0 -342
- package/esm2015/lib/modules/colorpicker/colorpicker.service.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/types/colorpicker-axis.js +0 -2
- package/esm2015/lib/modules/colorpicker/types/colorpicker-axis.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/types/colorpicker-cmyk.js +0 -2
- package/esm2015/lib/modules/colorpicker/types/colorpicker-cmyk.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/types/colorpicker-color.js +0 -2
- package/esm2015/lib/modules/colorpicker/types/colorpicker-color.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/types/colorpicker-hsla.js +0 -2
- package/esm2015/lib/modules/colorpicker/types/colorpicker-hsla.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/types/colorpicker-hsva.js +0 -2
- package/esm2015/lib/modules/colorpicker/types/colorpicker-hsva.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/types/colorpicker-message-type.js +0 -23
- package/esm2015/lib/modules/colorpicker/types/colorpicker-message-type.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/types/colorpicker-message.js +0 -2
- package/esm2015/lib/modules/colorpicker/types/colorpicker-message.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/types/colorpicker-output.js +0 -2
- package/esm2015/lib/modules/colorpicker/types/colorpicker-output.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/types/colorpicker-result.js +0 -2
- package/esm2015/lib/modules/colorpicker/types/colorpicker-result.js.map +0 -1
- package/esm2015/lib/modules/colorpicker/types/colorpicker-rgba.js +0 -2
- package/esm2015/lib/modules/colorpicker/types/colorpicker-rgba.js.map +0 -1
- package/esm2015/lib/modules/shared/sky-colorpicker-resources.module.js +0 -64
- package/esm2015/lib/modules/shared/sky-colorpicker-resources.module.js.map +0 -1
- package/esm2015/skyux-colorpicker.js +0 -5
- package/esm2015/skyux-colorpicker.js.map +0 -1
- package/esm2015/testing/colorpicker-fixture.js +0 -96
- package/esm2015/testing/colorpicker-fixture.js.map +0 -1
- package/esm2015/testing/public-api.js +0 -2
- package/esm2015/testing/public-api.js.map +0 -1
- package/esm2015/testing/skyux-colorpicker-testing.js +0 -5
- package/esm2015/testing/skyux-colorpicker-testing.js.map +0 -1
- package/fesm2015/skyux-colorpicker-testing.js.map +0 -1
- package/fesm2015/skyux-colorpicker.js +0 -1324
- package/fesm2015/skyux-colorpicker.js.map +0 -1
package/documentation.json
CHANGED
|
@@ -139,7 +139,7 @@
|
|
|
139
139
|
"name": "NgModule"
|
|
140
140
|
},
|
|
141
141
|
"arguments": {
|
|
142
|
-
"obj": "{\n declarations: [\n SkyColorpickerComponent,\n SkyColorpickerInputDirective,\n SkyColorpickerTextDirective,\n SkyColorpickerSliderDirective,\n ],\n imports: [\n CommonModule,\n SkyAffixModule,\n SkyColorpickerResourcesModule,\n SkyI18nModule,\n SkyIconModule,\n SkyInputBoxModule,\n SkyOverlayModule,\n SkyThemeModule,\n ],\n exports: [SkyColorpickerComponent, SkyColorpickerInputDirective],\n
|
|
142
|
+
"obj": "{\n declarations: [\n SkyColorpickerComponent,\n SkyColorpickerInputDirective,\n SkyColorpickerTextDirective,\n SkyColorpickerSliderDirective,\n ],\n imports: [\n CommonModule,\n SkyAffixModule,\n SkyColorpickerResourcesModule,\n SkyI18nModule,\n SkyIconModule,\n SkyInputBoxModule,\n SkyOverlayModule,\n SkyThemeModule,\n ],\n exports: [SkyColorpickerComponent, SkyColorpickerInputDirective],\n}"
|
|
143
143
|
}
|
|
144
144
|
}
|
|
145
145
|
],
|
|
@@ -156,7 +156,7 @@
|
|
|
156
156
|
"sources": [
|
|
157
157
|
{
|
|
158
158
|
"fileName": "projects/colorpicker/src/modules/colorpicker/colorpicker.module.ts",
|
|
159
|
-
"line":
|
|
159
|
+
"line": 35,
|
|
160
160
|
"character": 13
|
|
161
161
|
}
|
|
162
162
|
]
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export * from './lib/modules/colorpicker/colorpicker.module';
|
|
2
|
+
export * from './lib/modules/colorpicker/types/colorpicker-axis';
|
|
3
|
+
export * from './lib/modules/colorpicker/types/colorpicker-cmyk';
|
|
4
|
+
export * from './lib/modules/colorpicker/types/colorpicker-color';
|
|
5
|
+
export * from './lib/modules/colorpicker/types/colorpicker-hsla';
|
|
6
|
+
export * from './lib/modules/colorpicker/types/colorpicker-hsva';
|
|
7
|
+
export * from './lib/modules/colorpicker/types/colorpicker-message';
|
|
8
|
+
export * from './lib/modules/colorpicker/types/colorpicker-message-type';
|
|
9
|
+
export * from './lib/modules/colorpicker/types/colorpicker-output';
|
|
10
|
+
export * from './lib/modules/colorpicker/types/colorpicker-result';
|
|
11
|
+
export * from './lib/modules/colorpicker/types/colorpicker-rgba';
|
|
12
|
+
// Components and directives must be exported to support Angular's "partial" Ivy compiler.
|
|
13
|
+
// Obscure names are used to indicate types are not part of the public API.
|
|
14
|
+
export { SkyColorpickerComponent as λ1 } from './lib/modules/colorpicker/colorpicker.component';
|
|
15
|
+
export { SkyColorpickerInputDirective as λ2 } from './lib/modules/colorpicker/colorpicker-input.directive';
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29sb3JwaWNrZXIvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLG9EQUFvRCxDQUFDO0FBQ25FLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyxrREFBa0QsQ0FBQztBQUVqRSwwRkFBMEY7QUFDMUYsMkVBQTJFO0FBQzNFLE9BQU8sRUFBRSx1QkFBdUIsSUFBSSxFQUFFLEVBQUUsTUFBTSxpREFBaUQsQ0FBQztBQUNoRyxPQUFPLEVBQUUsNEJBQTRCLElBQUksRUFBRSxFQUFFLE1BQU0sdURBQXVELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbG9ycGlja2VyL2NvbG9ycGlja2VyLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbG9ycGlja2VyL3R5cGVzL2NvbG9ycGlja2VyLWF4aXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9jb2xvcnBpY2tlci90eXBlcy9jb2xvcnBpY2tlci1jbXlrJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvY29sb3JwaWNrZXIvdHlwZXMvY29sb3JwaWNrZXItY29sb3InO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9jb2xvcnBpY2tlci90eXBlcy9jb2xvcnBpY2tlci1oc2xhJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZHVsZXMvY29sb3JwaWNrZXIvdHlwZXMvY29sb3JwaWNrZXItaHN2YSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbG9ycGlja2VyL3R5cGVzL2NvbG9ycGlja2VyLW1lc3NhZ2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9jb2xvcnBpY2tlci90eXBlcy9jb2xvcnBpY2tlci1tZXNzYWdlLXR5cGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9jb2xvcnBpY2tlci90eXBlcy9jb2xvcnBpY2tlci1vdXRwdXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9jb2xvcnBpY2tlci90eXBlcy9jb2xvcnBpY2tlci1yZXN1bHQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbW9kdWxlcy9jb2xvcnBpY2tlci90eXBlcy9jb2xvcnBpY2tlci1yZ2JhJztcblxuLy8gQ29tcG9uZW50cyBhbmQgZGlyZWN0aXZlcyBtdXN0IGJlIGV4cG9ydGVkIHRvIHN1cHBvcnQgQW5ndWxhcidzIFwicGFydGlhbFwiIEl2eSBjb21waWxlci5cbi8vIE9ic2N1cmUgbmFtZXMgYXJlIHVzZWQgdG8gaW5kaWNhdGUgdHlwZXMgYXJlIG5vdCBwYXJ0IG9mIHRoZSBwdWJsaWMgQVBJLlxuZXhwb3J0IHsgU2t5Q29sb3JwaWNrZXJDb21wb25lbnQgYXMgzrsxIH0gZnJvbSAnLi9saWIvbW9kdWxlcy9jb2xvcnBpY2tlci9jb2xvcnBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0IHsgU2t5Q29sb3JwaWNrZXJJbnB1dERpcmVjdGl2ZSBhcyDOuzIgfSBmcm9tICcuL2xpYi9tb2R1bGVzL2NvbG9ycGlja2VyL2NvbG9ycGlja2VyLWlucHV0LmRpcmVjdGl2ZSc7XG4iXX0=
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
// spell-checker:ignore colorpicker
|
|
2
|
+
/**
|
|
3
|
+
* @internal
|
|
4
|
+
*/
|
|
5
|
+
export class SliderPosition {
|
|
6
|
+
constructor(hue, saturation, value, alpha) {
|
|
7
|
+
this.hue = hue;
|
|
8
|
+
this.saturation = saturation;
|
|
9
|
+
this.value = value;
|
|
10
|
+
this.alpha = alpha;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* @internal
|
|
15
|
+
*/
|
|
16
|
+
export class SliderDimension {
|
|
17
|
+
constructor(hue, saturation, value, alpha) {
|
|
18
|
+
this.hue = hue;
|
|
19
|
+
this.saturation = saturation;
|
|
20
|
+
this.value = value;
|
|
21
|
+
this.alpha = alpha;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3JwaWNrZXItY2xhc3Nlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb2xvcnBpY2tlci9zcmMvbGliL21vZHVsZXMvY29sb3JwaWNrZXIvY29sb3JwaWNrZXItY2xhc3Nlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxtQ0FBbUM7QUFFbkM7O0dBRUc7QUFDSCxNQUFNLE9BQU8sY0FBYztJQUN6QixZQUNTLEdBQVcsRUFDWCxVQUFrQixFQUNsQixLQUFhLEVBQ2IsS0FBYTtRQUhiLFFBQUcsR0FBSCxHQUFHLENBQVE7UUFDWCxlQUFVLEdBQVYsVUFBVSxDQUFRO1FBQ2xCLFVBQUssR0FBTCxLQUFLLENBQVE7UUFDYixVQUFLLEdBQUwsS0FBSyxDQUFRO0lBQ25CLENBQUM7Q0FDTDtBQUNEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGVBQWU7SUFDMUIsWUFDUyxHQUFXLEVBQ1gsVUFBa0IsRUFDbEIsS0FBYSxFQUNiLEtBQWE7UUFIYixRQUFHLEdBQUgsR0FBRyxDQUFRO1FBQ1gsZUFBVSxHQUFWLFVBQVUsQ0FBUTtRQUNsQixVQUFLLEdBQUwsS0FBSyxDQUFRO1FBQ2IsVUFBSyxHQUFMLEtBQUssQ0FBUTtJQUNuQixDQUFDO0NBQ0wiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBzcGVsbC1jaGVja2VyOmlnbm9yZSBjb2xvcnBpY2tlclxuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY2xhc3MgU2xpZGVyUG9zaXRpb24ge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgaHVlOiBudW1iZXIsXG4gICAgcHVibGljIHNhdHVyYXRpb246IG51bWJlcixcbiAgICBwdWJsaWMgdmFsdWU6IG51bWJlcixcbiAgICBwdWJsaWMgYWxwaGE6IG51bWJlclxuICApIHt9XG59XG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY2xhc3MgU2xpZGVyRGltZW5zaW9uIHtcbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIGh1ZTogbnVtYmVyLFxuICAgIHB1YmxpYyBzYXR1cmF0aW9uOiBudW1iZXIsXG4gICAgcHVibGljIHZhbHVlOiBudW1iZXIsXG4gICAgcHVibGljIGFscGhhOiBudW1iZXJcbiAgKSB7fVxufVxuIl19
|
|
@@ -0,0 +1,264 @@
|
|
|
1
|
+
import { Directive, ElementRef, HostListener, Injector, Input, Renderer2, forwardRef, } from '@angular/core';
|
|
2
|
+
import { NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, } from '@angular/forms';
|
|
3
|
+
import { SkyLibResourcesService } from '@skyux/i18n';
|
|
4
|
+
import { SkyColorpickerComponent } from './colorpicker.component';
|
|
5
|
+
import { SkyColorpickerService } from './colorpicker.service';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "./colorpicker.service";
|
|
8
|
+
import * as i2 from "@skyux/i18n";
|
|
9
|
+
// tslint:disable:no-forward-ref no-use-before-declare
|
|
10
|
+
const SKY_COLORPICKER_VALUE_ACCESSOR = {
|
|
11
|
+
provide: NG_VALUE_ACCESSOR,
|
|
12
|
+
useExisting: forwardRef(() => SkyColorpickerInputDirective),
|
|
13
|
+
multi: true,
|
|
14
|
+
};
|
|
15
|
+
const SKY_COLORPICKER_VALIDATOR = {
|
|
16
|
+
provide: NG_VALIDATORS,
|
|
17
|
+
useExisting: forwardRef(() => SkyColorpickerInputDirective),
|
|
18
|
+
multi: true,
|
|
19
|
+
};
|
|
20
|
+
// tslint:enable
|
|
21
|
+
const SKY_COLORPICKER_DEFAULT_COLOR = '#FFFFFF';
|
|
22
|
+
/**
|
|
23
|
+
* Creates the colorpicker element and dropdown.
|
|
24
|
+
*/
|
|
25
|
+
export class SkyColorpickerInputDirective {
|
|
26
|
+
constructor(elementRef, renderer, service, resourcesService, injector) {
|
|
27
|
+
this.elementRef = elementRef;
|
|
28
|
+
this.renderer = renderer;
|
|
29
|
+
this.service = service;
|
|
30
|
+
this.resourcesService = resourcesService;
|
|
31
|
+
this.injector = injector;
|
|
32
|
+
/**
|
|
33
|
+
* This property is deprecated and does not affect the colorpicker.
|
|
34
|
+
* We recommend against using it.
|
|
35
|
+
* @deprecated
|
|
36
|
+
* @default "rgba"
|
|
37
|
+
*/
|
|
38
|
+
this.returnFormat = 'rgba';
|
|
39
|
+
/**
|
|
40
|
+
* Specifies the format to use for the color when the colorpicker uses a native input
|
|
41
|
+
* element such as a standard text input or a button. This property accepts `rgba`, `hex`,
|
|
42
|
+
* or `hsla`, but we do not recommend using it because users never see or use its value.
|
|
43
|
+
* Instead, if you need to access this format value, see the demo for an example.
|
|
44
|
+
*@default "rgba"
|
|
45
|
+
*/
|
|
46
|
+
this.outputFormat = 'rgba';
|
|
47
|
+
/**
|
|
48
|
+
* Specifies an array of colors to load as preset choices. The colorpicker displays the
|
|
49
|
+
* colors in a series of 12 boxes for users to select.
|
|
50
|
+
*/
|
|
51
|
+
this.presetColors = ['#333', '#888', '#EFEFEF', '#FFF'];
|
|
52
|
+
/**
|
|
53
|
+
* Specifies the type of transparency to use in the transparency slider.
|
|
54
|
+
*@default "hex6"
|
|
55
|
+
*/
|
|
56
|
+
this.alphaChannel = 'hex6';
|
|
57
|
+
/**
|
|
58
|
+
* Indicates whether to display a transparency slider for users to select transparency
|
|
59
|
+
* levels.
|
|
60
|
+
*/
|
|
61
|
+
this.allowTransparency = true;
|
|
62
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
63
|
+
this._onChange = (_) => { };
|
|
64
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
65
|
+
this._onTouched = () => { };
|
|
66
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
67
|
+
this._validatorChange = () => { };
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Specifies an initial color to load in the colorpicker. Use a reactive or
|
|
71
|
+
* template-driven form to set this value. This property is deprecated. As an alternative,
|
|
72
|
+
* we recommend the `formControlName` property on reactive forms or `ngModel` on
|
|
73
|
+
* template-driven forms. See the demo for examples.
|
|
74
|
+
* @deprecated
|
|
75
|
+
*/
|
|
76
|
+
set initialColor(value) {
|
|
77
|
+
/* istanbul ignore else */
|
|
78
|
+
if (!this._initialColor && !this.modelValue) {
|
|
79
|
+
this.writeValue(value);
|
|
80
|
+
}
|
|
81
|
+
this._initialColor = value;
|
|
82
|
+
}
|
|
83
|
+
get initialColor() {
|
|
84
|
+
return this._initialColor || SKY_COLORPICKER_DEFAULT_COLOR;
|
|
85
|
+
}
|
|
86
|
+
changeInput(event) {
|
|
87
|
+
const value = event.target.value;
|
|
88
|
+
this.skyColorpickerInput.updatePickerValues(value);
|
|
89
|
+
this.skyColorpickerInput.backgroundColorForDisplay = value;
|
|
90
|
+
}
|
|
91
|
+
onChange(event) {
|
|
92
|
+
const newValue = event.target.value;
|
|
93
|
+
this.modelValue = this.formatter(newValue);
|
|
94
|
+
this._validatorChange();
|
|
95
|
+
this._onChange(this.modelValue);
|
|
96
|
+
this.writeModelValue(this.modelValue);
|
|
97
|
+
}
|
|
98
|
+
/* istanbul ignore next */
|
|
99
|
+
onBlur() {
|
|
100
|
+
/*istanbul ignore next */
|
|
101
|
+
this._onTouched();
|
|
102
|
+
}
|
|
103
|
+
ngOnInit() {
|
|
104
|
+
const element = this.elementRef.nativeElement;
|
|
105
|
+
this.renderer.addClass(element, 'sky-form-control');
|
|
106
|
+
this.skyColorpickerInput.initialColor = this.initialColor;
|
|
107
|
+
this.skyColorpickerInput.returnFormat = this.returnFormat;
|
|
108
|
+
this.pickerChangedSubscription =
|
|
109
|
+
this.skyColorpickerInput.selectedColorChanged.subscribe((newColor) => {
|
|
110
|
+
/* istanbul ignore else */
|
|
111
|
+
if (newColor) {
|
|
112
|
+
this.modelValue = this.formatter(newColor);
|
|
113
|
+
this.writeModelValue(this.modelValue);
|
|
114
|
+
}
|
|
115
|
+
this._onChange(newColor);
|
|
116
|
+
});
|
|
117
|
+
this.skyColorpickerInput.updatePickerValues(this.initialColor);
|
|
118
|
+
/* Sanity check */
|
|
119
|
+
/* istanbul ignore else */
|
|
120
|
+
if (!this._disabled) {
|
|
121
|
+
this.skyColorpickerInput.backgroundColorForDisplay = this.initialColor;
|
|
122
|
+
}
|
|
123
|
+
/// Set aria-label as default, if not set
|
|
124
|
+
if (!element.getAttribute('aria-label')) {
|
|
125
|
+
this.renderer.setAttribute(element, 'aria-label', this.getString('skyux_colorpicker_input_default_label'));
|
|
126
|
+
}
|
|
127
|
+
const typeAttr = element.getAttribute('type');
|
|
128
|
+
if (typeAttr && typeAttr === 'hidden') {
|
|
129
|
+
this.skyColorpickerInput.isVisible = false;
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
this.skyColorpickerInput.isVisible = true;
|
|
133
|
+
}
|
|
134
|
+
element.setAttribute('readonly', 'true');
|
|
135
|
+
this.renderer.addClass(element, 'sky-colorpicker-input');
|
|
136
|
+
}
|
|
137
|
+
ngOnDestroy() {
|
|
138
|
+
this.pickerChangedSubscription.unsubscribe();
|
|
139
|
+
}
|
|
140
|
+
setColorPickerDefaults() {
|
|
141
|
+
this.skyColorpickerInput.setDialog(this, this.elementRef, this.initialColor, this.outputFormat, this.presetColors, this.alphaChannel, this.allowTransparency);
|
|
142
|
+
}
|
|
143
|
+
ngOnChanges() {
|
|
144
|
+
this._validatorChange();
|
|
145
|
+
this.skyColorpickerInput.returnFormat = this.returnFormat;
|
|
146
|
+
this.setColorPickerDefaults();
|
|
147
|
+
}
|
|
148
|
+
registerOnChange(fn) {
|
|
149
|
+
this._onChange = fn;
|
|
150
|
+
}
|
|
151
|
+
registerOnTouched(fn) {
|
|
152
|
+
this._onTouched = fn;
|
|
153
|
+
}
|
|
154
|
+
registerOnValidatorChange(fn) {
|
|
155
|
+
this._validatorChange = fn;
|
|
156
|
+
}
|
|
157
|
+
writeValue(value) {
|
|
158
|
+
if (this.skyColorpickerInput &&
|
|
159
|
+
value &&
|
|
160
|
+
value !== this.skyColorpickerInput.lastAppliedColor) {
|
|
161
|
+
this.modelValue = this.formatter(value);
|
|
162
|
+
this.writeModelValue(this.modelValue);
|
|
163
|
+
if (!this._initialColor) {
|
|
164
|
+
this._initialColor = value;
|
|
165
|
+
this.skyColorpickerInput.initialColor = value;
|
|
166
|
+
}
|
|
167
|
+
this.skyColorpickerInput.lastAppliedColor = value;
|
|
168
|
+
const control = this.injector.get(NgControl)
|
|
169
|
+
.control;
|
|
170
|
+
if (control) {
|
|
171
|
+
control.setValue(this.modelValue, { emitEvent: false });
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
validate(control) {
|
|
176
|
+
const value = control.value;
|
|
177
|
+
if (!value) {
|
|
178
|
+
return;
|
|
179
|
+
}
|
|
180
|
+
// Validation
|
|
181
|
+
}
|
|
182
|
+
/**
|
|
183
|
+
* Implemented as part of ControlValueAccessor.
|
|
184
|
+
*/
|
|
185
|
+
setDisabledState(isDisabled) {
|
|
186
|
+
this._disabled = isDisabled;
|
|
187
|
+
this.skyColorpickerInput.disabled = isDisabled;
|
|
188
|
+
if (this._disabled) {
|
|
189
|
+
this.skyColorpickerInput.backgroundColorForDisplay = '#fff';
|
|
190
|
+
}
|
|
191
|
+
else {
|
|
192
|
+
this.skyColorpickerInput.backgroundColorForDisplay = this.modelValue.hex;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
writeModelValue(model) {
|
|
196
|
+
const setElementValue = model.rgbaText;
|
|
197
|
+
const element = this.elementRef.nativeElement;
|
|
198
|
+
let output;
|
|
199
|
+
// tslint:disable-next-line:switch-default
|
|
200
|
+
switch (this.outputFormat) {
|
|
201
|
+
case 'rgba':
|
|
202
|
+
output = model.rgbaText;
|
|
203
|
+
break;
|
|
204
|
+
case 'hsla':
|
|
205
|
+
output = model.hslaText;
|
|
206
|
+
break;
|
|
207
|
+
case 'cmyk':
|
|
208
|
+
output = model.cmykText;
|
|
209
|
+
break;
|
|
210
|
+
case 'hex':
|
|
211
|
+
output = model.hex;
|
|
212
|
+
break;
|
|
213
|
+
}
|
|
214
|
+
this.skyColorpickerInput.updatePickerValues(output);
|
|
215
|
+
this.skyColorpickerInput.backgroundColorForDisplay = output;
|
|
216
|
+
this.renderer.setStyle(element, 'background-color', setElementValue);
|
|
217
|
+
this.renderer.setProperty(element, 'value', output);
|
|
218
|
+
}
|
|
219
|
+
formatter(color) {
|
|
220
|
+
if (color && typeof color !== 'string') {
|
|
221
|
+
return color;
|
|
222
|
+
}
|
|
223
|
+
const hsva = this.service.stringToHsva(color, this.alphaChannel === 'hex8');
|
|
224
|
+
const formatColor = this.service.skyColorpickerOut(hsva);
|
|
225
|
+
return formatColor;
|
|
226
|
+
}
|
|
227
|
+
getString(key) {
|
|
228
|
+
// TODO: Need to implement the async `getString` method in a breaking change.
|
|
229
|
+
return this.resourcesService.getStringForLocale({ locale: 'en-US' }, key);
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
SkyColorpickerInputDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyColorpickerInputDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.SkyColorpickerService }, { token: i2.SkyLibResourcesService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive });
|
|
233
|
+
SkyColorpickerInputDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.7", type: SkyColorpickerInputDirective, selector: "[skyColorpickerInput]", inputs: { skyColorpickerInput: "skyColorpickerInput", initialColor: "initialColor", returnFormat: "returnFormat", outputFormat: "outputFormat", presetColors: "presetColors", alphaChannel: "alphaChannel", allowTransparency: "allowTransparency" }, host: { listeners: { "input": "changeInput($event)", "change": "onChange($event)", "blur": "onBlur()" } }, providers: [SKY_COLORPICKER_VALUE_ACCESSOR, SKY_COLORPICKER_VALIDATOR], usesOnChanges: true, ngImport: i0 });
|
|
234
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyColorpickerInputDirective, decorators: [{
|
|
235
|
+
type: Directive,
|
|
236
|
+
args: [{
|
|
237
|
+
selector: '[skyColorpickerInput]',
|
|
238
|
+
providers: [SKY_COLORPICKER_VALUE_ACCESSOR, SKY_COLORPICKER_VALIDATOR],
|
|
239
|
+
}]
|
|
240
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.SkyColorpickerService }, { type: i2.SkyLibResourcesService }, { type: i0.Injector }]; }, propDecorators: { skyColorpickerInput: [{
|
|
241
|
+
type: Input
|
|
242
|
+
}], initialColor: [{
|
|
243
|
+
type: Input
|
|
244
|
+
}], returnFormat: [{
|
|
245
|
+
type: Input
|
|
246
|
+
}], outputFormat: [{
|
|
247
|
+
type: Input
|
|
248
|
+
}], presetColors: [{
|
|
249
|
+
type: Input
|
|
250
|
+
}], alphaChannel: [{
|
|
251
|
+
type: Input
|
|
252
|
+
}], allowTransparency: [{
|
|
253
|
+
type: Input
|
|
254
|
+
}], changeInput: [{
|
|
255
|
+
type: HostListener,
|
|
256
|
+
args: ['input', ['$event']]
|
|
257
|
+
}], onChange: [{
|
|
258
|
+
type: HostListener,
|
|
259
|
+
args: ['change', ['$event']]
|
|
260
|
+
}], onBlur: [{
|
|
261
|
+
type: HostListener,
|
|
262
|
+
args: ['blur']
|
|
263
|
+
}] } });
|
|
264
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"colorpicker-input.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/colorpicker/src/lib/modules/colorpicker/colorpicker-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  HostListener,\n  Injector,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  forwardRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  NgControl,\n  Validator,\n} from '@angular/forms';\nimport { SkyLibResourcesService } from '@skyux/i18n';\n\nimport { Subscription } from 'rxjs';\n\nimport { SkyColorpickerComponent } from './colorpicker.component';\nimport { SkyColorpickerService } from './colorpicker.service';\nimport { SkyColorpickerHsva } from './types/colorpicker-hsva';\nimport { SkyColorpickerOutput } from './types/colorpicker-output';\n\n// tslint:disable:no-forward-ref no-use-before-declare\nconst SKY_COLORPICKER_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => SkyColorpickerInputDirective),\n  multi: true,\n};\n\nconst SKY_COLORPICKER_VALIDATOR = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => SkyColorpickerInputDirective),\n  multi: true,\n};\n// tslint:enable\nconst SKY_COLORPICKER_DEFAULT_COLOR = '#FFFFFF';\n\n/**\n * Creates the colorpicker element and dropdown.\n */\n@Directive({\n  selector: '[skyColorpickerInput]',\n  providers: [SKY_COLORPICKER_VALUE_ACCESSOR, SKY_COLORPICKER_VALIDATOR],\n})\nexport class SkyColorpickerInputDirective\n  implements OnInit, OnChanges, ControlValueAccessor, Validator, OnDestroy\n{\n  public pickerChangedSubscription: Subscription;\n\n  /**\n   * Creates the colorpicker element and dropdown. Place this attribute on an `input` element\n   * or `button` element, wrap the element in a `sky-colorpicker` component, and set the attribute\n   * to the instance of the `sky-colorpicker` component.\n   * @required\n   */\n  @Input()\n  public skyColorpickerInput: SkyColorpickerComponent;\n\n  /**\n   * Specifies an initial color to load in the colorpicker. Use a reactive or\n   * template-driven form to set this value. This property is deprecated. As an alternative,\n   * we recommend the `formControlName` property on reactive forms or `ngModel` on\n   * template-driven forms. See the demo for examples.\n   * @deprecated\n   */\n  @Input()\n  public set initialColor(value: string) {\n    /* istanbul ignore else */\n    if (!this._initialColor && !this.modelValue) {\n      this.writeValue(value);\n    }\n    this._initialColor = value;\n  }\n\n  public get initialColor(): string {\n    return this._initialColor || SKY_COLORPICKER_DEFAULT_COLOR;\n  }\n\n  /**\n   * This property is deprecated and does not affect the colorpicker.\n   * We recommend against using it.\n   * @deprecated\n   * @default \"rgba\"\n   */\n  @Input()\n  public returnFormat = 'rgba';\n\n  /**\n   * Specifies the format to use for the color when the colorpicker uses a native input\n   * element such as a standard text input or a button. This property accepts `rgba`, `hex`,\n   * or `hsla`, but we do not recommend using it because users never see or use its value.\n   * Instead, if you need to access this format value, see the demo for an example.\n   *@default \"rgba\"\n   */\n  @Input()\n  public outputFormat = 'rgba';\n\n  /**\n   * Specifies an array of colors to load as preset choices. The colorpicker displays the\n   * colors in a series of 12 boxes for users to select.\n   */\n  @Input()\n  public presetColors = ['#333', '#888', '#EFEFEF', '#FFF'];\n\n  /**\n   * Specifies the type of transparency to use in the transparency slider.\n   *@default \"hex6\"\n   */\n  @Input()\n  public alphaChannel = 'hex6';\n\n  /**\n   * Indicates whether to display a transparency slider for users to select transparency\n   * levels.\n   */\n  @Input()\n  public allowTransparency = true;\n\n  private _disabled: boolean;\n  private _initialColor: string;\n  private modelValue: SkyColorpickerOutput;\n\n  constructor(\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private service: SkyColorpickerService,\n    private resourcesService: SkyLibResourcesService,\n    private injector: Injector\n  ) {}\n\n  @HostListener('input', ['$event'])\n  public changeInput(event: any) {\n    const value = event.target.value;\n    this.skyColorpickerInput.updatePickerValues(value);\n    this.skyColorpickerInput.backgroundColorForDisplay = value;\n  }\n\n  @HostListener('change', ['$event'])\n  public onChange(event: any) {\n    const newValue = event.target.value;\n    this.modelValue = this.formatter(newValue);\n    this._validatorChange();\n    this._onChange(this.modelValue);\n    this.writeModelValue(this.modelValue);\n  }\n\n  /* istanbul ignore next */\n  @HostListener('blur')\n  public onBlur() {\n    /*istanbul ignore next */\n    this._onTouched();\n  }\n\n  public ngOnInit() {\n    const element = this.elementRef.nativeElement;\n\n    this.renderer.addClass(element, 'sky-form-control');\n    this.skyColorpickerInput.initialColor = this.initialColor;\n    this.skyColorpickerInput.returnFormat = this.returnFormat;\n\n    this.pickerChangedSubscription =\n      this.skyColorpickerInput.selectedColorChanged.subscribe(\n        (newColor: SkyColorpickerOutput) => {\n          /* istanbul ignore else */\n          if (newColor) {\n            this.modelValue = this.formatter(newColor);\n            this.writeModelValue(this.modelValue);\n          }\n          this._onChange(newColor);\n        }\n      );\n\n    this.skyColorpickerInput.updatePickerValues(this.initialColor);\n\n    /* Sanity check */\n    /* istanbul ignore else */\n    if (!this._disabled) {\n      this.skyColorpickerInput.backgroundColorForDisplay = this.initialColor;\n    }\n\n    /// Set aria-label as default, if not set\n    if (!element.getAttribute('aria-label')) {\n      this.renderer.setAttribute(\n        element,\n        'aria-label',\n        this.getString('skyux_colorpicker_input_default_label')\n      );\n    }\n\n    const typeAttr = element.getAttribute('type');\n    if (typeAttr && typeAttr === 'hidden') {\n      this.skyColorpickerInput.isVisible = false;\n    } else {\n      this.skyColorpickerInput.isVisible = true;\n    }\n\n    element.setAttribute('readonly', 'true');\n    this.renderer.addClass(element, 'sky-colorpicker-input');\n  }\n\n  public ngOnDestroy() {\n    this.pickerChangedSubscription.unsubscribe();\n  }\n\n  public setColorPickerDefaults() {\n    this.skyColorpickerInput.setDialog(\n      this,\n      this.elementRef,\n      this.initialColor,\n      this.outputFormat,\n      this.presetColors,\n      this.alphaChannel,\n      this.allowTransparency\n    );\n  }\n\n  public ngOnChanges(): void {\n    this._validatorChange();\n    this.skyColorpickerInput.returnFormat = this.returnFormat;\n    this.setColorPickerDefaults();\n  }\n\n  public registerOnChange(fn: (value: any) => any): void {\n    this._onChange = fn;\n  }\n  public registerOnTouched(fn: () => any): void {\n    this._onTouched = fn;\n  }\n  public registerOnValidatorChange(fn: () => void): void {\n    this._validatorChange = fn;\n  }\n\n  public writeValue(value: any) {\n    if (\n      this.skyColorpickerInput &&\n      value &&\n      value !== this.skyColorpickerInput.lastAppliedColor\n    ) {\n      this.modelValue = this.formatter(value);\n      this.writeModelValue(this.modelValue);\n\n      if (!this._initialColor) {\n        this._initialColor = value;\n        this.skyColorpickerInput.initialColor = value;\n      }\n      this.skyColorpickerInput.lastAppliedColor = value;\n      const control: FormControl = this.injector.get<NgControl>(NgControl)\n        .control as FormControl;\n      if (control) {\n        control.setValue(this.modelValue, { emitEvent: false });\n      }\n    }\n  }\n\n  public validate(control: AbstractControl): { [key: string]: any } {\n    const value = control.value;\n    if (!value) {\n      return;\n    }\n    // Validation\n  }\n\n  /**\n   * Implemented as part of ControlValueAccessor.\n   */\n  public setDisabledState(isDisabled: boolean): void {\n    this._disabled = isDisabled;\n    this.skyColorpickerInput.disabled = isDisabled;\n    if (this._disabled) {\n      this.skyColorpickerInput.backgroundColorForDisplay = '#fff';\n    } else {\n      this.skyColorpickerInput.backgroundColorForDisplay = this.modelValue.hex;\n    }\n  }\n\n  private writeModelValue(model: SkyColorpickerOutput) {\n    const setElementValue = model.rgbaText;\n    const element = this.elementRef.nativeElement;\n\n    let output: string;\n    // tslint:disable-next-line:switch-default\n    switch (this.outputFormat) {\n      case 'rgba':\n        output = model.rgbaText;\n        break;\n\n      case 'hsla':\n        output = model.hslaText;\n        break;\n\n      case 'cmyk':\n        output = model.cmykText;\n        break;\n\n      case 'hex':\n        output = model.hex;\n        break;\n    }\n\n    this.skyColorpickerInput.updatePickerValues(output);\n    this.skyColorpickerInput.backgroundColorForDisplay = output;\n\n    this.renderer.setStyle(element, 'background-color', setElementValue);\n    this.renderer.setProperty(element, 'value', output);\n  }\n\n  private formatter(color: any) {\n    if (color && typeof color !== 'string') {\n      return color;\n    }\n\n    const hsva: SkyColorpickerHsva = this.service.stringToHsva(\n      color,\n      this.alphaChannel === 'hex8'\n    );\n\n    const formatColor = this.service.skyColorpickerOut(hsva);\n\n    return formatColor;\n  }\n\n  private getString(key: string): string {\n    // TODO: Need to implement the async `getString` method in a breaking change.\n    return this.resourcesService.getStringForLocale({ locale: 'en-US' }, key);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  private _onChange = (_: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  private _onTouched = () => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  private _validatorChange = () => {};\n}\n"]}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
// spell-checker:ignore Colorpicker
|
|
2
|
+
import { Directive, ElementRef, EventEmitter, HostListener, Input, Output, } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
export class SkyColorpickerSliderDirective {
|
|
8
|
+
constructor(el) {
|
|
9
|
+
this.el = el;
|
|
10
|
+
this.newColorContrast = new EventEmitter();
|
|
11
|
+
this.listenerMove = (event) => {
|
|
12
|
+
this.move(event);
|
|
13
|
+
};
|
|
14
|
+
this.listenerStop = () => {
|
|
15
|
+
this.stop();
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
setCursor(event) {
|
|
19
|
+
const height = this.el.nativeElement.offsetHeight;
|
|
20
|
+
const width = this.el.nativeElement.offsetWidth;
|
|
21
|
+
const xAxis = Math.max(0, Math.min(this.getX(event), width));
|
|
22
|
+
const yAxis = Math.max(0, Math.min(this.getY(event), height));
|
|
23
|
+
if (this.xAxis !== undefined && this.yAxis !== undefined) {
|
|
24
|
+
this.newColorContrast.emit({
|
|
25
|
+
xCoordinate: xAxis / width,
|
|
26
|
+
yCoordinate: 1 - yAxis / height,
|
|
27
|
+
xAxis: this.xAxis,
|
|
28
|
+
yAxis: this.yAxis,
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
this.newColorContrast.emit({
|
|
33
|
+
xCoordinate: xAxis / width,
|
|
34
|
+
maxRange: this.xAxis,
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
/* // No vertical bars
|
|
38
|
+
if (this.xAxis === undefined && this.yAxis !== undefined) {
|
|
39
|
+
this.newColorContrast.emit({ yCoordinate: yAxis / height, maxRange: this.yAxis });
|
|
40
|
+
} */
|
|
41
|
+
}
|
|
42
|
+
move(event) {
|
|
43
|
+
event.preventDefault();
|
|
44
|
+
this.setCursor(event);
|
|
45
|
+
}
|
|
46
|
+
start(event) {
|
|
47
|
+
this.setCursor(event);
|
|
48
|
+
document.addEventListener('mousemove', this.listenerMove);
|
|
49
|
+
document.addEventListener('touchmove', this.listenerMove);
|
|
50
|
+
document.addEventListener('mouseup', this.listenerStop);
|
|
51
|
+
document.addEventListener('touchend', this.listenerStop);
|
|
52
|
+
}
|
|
53
|
+
stop() {
|
|
54
|
+
document.removeEventListener('mousemove', this.listenerMove);
|
|
55
|
+
document.removeEventListener('touchmove', this.listenerMove);
|
|
56
|
+
document.removeEventListener('mouseup', this.listenerStop);
|
|
57
|
+
document.removeEventListener('touchend', this.listenerStop);
|
|
58
|
+
}
|
|
59
|
+
getX(event) {
|
|
60
|
+
/* Ignoring event.touches as tests are not run on a touch device. */
|
|
61
|
+
/* istanbul ignore next */
|
|
62
|
+
return ((event.pageX !== undefined ? event.pageX : event.touches[0].pageX) -
|
|
63
|
+
this.el.nativeElement.getBoundingClientRect().left -
|
|
64
|
+
window.pageXOffset);
|
|
65
|
+
}
|
|
66
|
+
getY(event) {
|
|
67
|
+
/* Ignoring event.touches as tests are not run on a touch device. */
|
|
68
|
+
/* istanbul ignore next */
|
|
69
|
+
return ((event.pageY !== undefined ? event.pageY : event.touches[0].pageY) -
|
|
70
|
+
this.el.nativeElement.getBoundingClientRect().top -
|
|
71
|
+
window.pageYOffset);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
SkyColorpickerSliderDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyColorpickerSliderDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
75
|
+
SkyColorpickerSliderDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.7", type: SkyColorpickerSliderDirective, selector: "[skyColorpickerSlider]", inputs: { skyColorpickerSlider: "skyColorpickerSlider", color: "color", xAxis: "xAxis", yAxis: "yAxis" }, outputs: { newColorContrast: "newColorContrast" }, host: { listeners: { "touchstart": "start($event)", "mousedown": "start($event)" } }, ngImport: i0 });
|
|
76
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyColorpickerSliderDirective, decorators: [{
|
|
77
|
+
type: Directive,
|
|
78
|
+
args: [{
|
|
79
|
+
selector: '[skyColorpickerSlider]',
|
|
80
|
+
}]
|
|
81
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { newColorContrast: [{
|
|
82
|
+
type: Output
|
|
83
|
+
}], skyColorpickerSlider: [{
|
|
84
|
+
type: Input
|
|
85
|
+
}], color: [{
|
|
86
|
+
type: Input
|
|
87
|
+
}], xAxis: [{
|
|
88
|
+
type: Input
|
|
89
|
+
}], yAxis: [{
|
|
90
|
+
type: Input
|
|
91
|
+
}], start: [{
|
|
92
|
+
type: HostListener,
|
|
93
|
+
args: ['touchstart', ['$event']]
|
|
94
|
+
}, {
|
|
95
|
+
type: HostListener,
|
|
96
|
+
args: ['mousedown', ['$event']]
|
|
97
|
+
}] } });
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"colorpicker-slider.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/colorpicker/src/lib/modules/colorpicker/colorpicker-slider.directive.ts"],"names":[],"mappings":"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","sourcesContent":["// spell-checker:ignore Colorpicker\nimport {\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  Output,\n} from '@angular/core';\n\nimport { SkyColorpickerChangeAxis } from './types/colorpicker-axis';\n\n/**\n * @internal\n */\n@Directive({\n  selector: '[skyColorpickerSlider]',\n})\nexport class SkyColorpickerSliderDirective {\n  @Output()\n  public newColorContrast = new EventEmitter<SkyColorpickerChangeAxis>();\n  @Input()\n  public skyColorpickerSlider: string;\n  @Input()\n  public color: string;\n  @Input()\n  public xAxis: number;\n  @Input()\n  public yAxis: number;\n\n  private listenerMove: any;\n  private listenerStop: any;\n\n  constructor(private el: ElementRef) {\n    this.listenerMove = (event: any) => {\n      this.move(event);\n    };\n    this.listenerStop = () => {\n      this.stop();\n    };\n  }\n\n  public setCursor(event: any) {\n    const height = this.el.nativeElement.offsetHeight;\n    const width = this.el.nativeElement.offsetWidth;\n    const xAxis = Math.max(0, Math.min(this.getX(event), width));\n    const yAxis = Math.max(0, Math.min(this.getY(event), height));\n    if (this.xAxis !== undefined && this.yAxis !== undefined) {\n      this.newColorContrast.emit({\n        xCoordinate: xAxis / width,\n        yCoordinate: 1 - yAxis / height,\n        xAxis: this.xAxis,\n        yAxis: this.yAxis,\n      } as SkyColorpickerChangeAxis);\n    } else {\n      this.newColorContrast.emit({\n        xCoordinate: xAxis / width,\n        maxRange: this.xAxis,\n      } as SkyColorpickerChangeAxis);\n    }\n    /* // No vertical bars\n     if (this.xAxis === undefined && this.yAxis !== undefined) {\n          this.newColorContrast.emit({ yCoordinate: yAxis / height, maxRange: this.yAxis });\n    } */\n  }\n\n  public move(event: any) {\n    event.preventDefault();\n    this.setCursor(event);\n  }\n  @HostListener('touchstart', ['$event'])\n  @HostListener('mousedown', ['$event'])\n  public start(event: MouseEvent) {\n    this.setCursor(event);\n    document.addEventListener('mousemove', this.listenerMove);\n    document.addEventListener('touchmove', this.listenerMove);\n    document.addEventListener('mouseup', this.listenerStop);\n    document.addEventListener('touchend', this.listenerStop);\n  }\n\n  public stop() {\n    document.removeEventListener('mousemove', this.listenerMove);\n    document.removeEventListener('touchmove', this.listenerMove);\n    document.removeEventListener('mouseup', this.listenerStop);\n    document.removeEventListener('touchend', this.listenerStop);\n  }\n\n  public getX(event: any): number {\n    /* Ignoring event.touches as tests are not run on a touch device. */\n    /* istanbul ignore next */\n    return (\n      (event.pageX !== undefined ? event.pageX : event.touches[0].pageX) -\n      this.el.nativeElement.getBoundingClientRect().left -\n      window.pageXOffset\n    );\n  }\n  public getY(event: any): number {\n    /* Ignoring event.touches as tests are not run on a touch device. */\n    /* istanbul ignore next */\n    return (\n      (event.pageY !== undefined ? event.pageY : event.touches[0].pageY) -\n      this.el.nativeElement.getBoundingClientRect().top -\n      window.pageYOffset\n    );\n  }\n}\n"]}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
// spell-checker:ignore Colorpicker
|
|
2
|
+
import { Directive, EventEmitter, HostListener, Input, Output, } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
export class SkyColorpickerTextDirective {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.newColorContrast = new EventEmitter();
|
|
10
|
+
}
|
|
11
|
+
changeInput(event) {
|
|
12
|
+
const element = event.target;
|
|
13
|
+
const elementValue = parseFloat(element.value);
|
|
14
|
+
if (this.maxRange === undefined) {
|
|
15
|
+
this.newColorContrast.emit({
|
|
16
|
+
color: element.value,
|
|
17
|
+
colorValue: undefined,
|
|
18
|
+
maxRange: undefined,
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
if (!isNaN(elementValue) &&
|
|
22
|
+
elementValue >= 0 &&
|
|
23
|
+
elementValue <= this.maxRange) {
|
|
24
|
+
this.newColorContrast.emit({
|
|
25
|
+
color: this.color,
|
|
26
|
+
colorValue: elementValue,
|
|
27
|
+
maxRange: this.maxRange,
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
SkyColorpickerTextDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyColorpickerTextDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
33
|
+
SkyColorpickerTextDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.7", type: SkyColorpickerTextDirective, selector: "[skyColorpickerText]", inputs: { skyColorpickerText: "skyColorpickerText", color: "color", maxRange: "maxRange" }, outputs: { newColorContrast: "newColorContrast" }, host: { listeners: { "input": "changeInput($event)" } }, ngImport: i0 });
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SkyColorpickerTextDirective, decorators: [{
|
|
35
|
+
type: Directive,
|
|
36
|
+
args: [{
|
|
37
|
+
selector: '[skyColorpickerText]',
|
|
38
|
+
}]
|
|
39
|
+
}], propDecorators: { newColorContrast: [{
|
|
40
|
+
type: Output
|
|
41
|
+
}], skyColorpickerText: [{
|
|
42
|
+
type: Input
|
|
43
|
+
}], color: [{
|
|
44
|
+
type: Input
|
|
45
|
+
}], maxRange: [{
|
|
46
|
+
type: Input
|
|
47
|
+
}], changeInput: [{
|
|
48
|
+
type: HostListener,
|
|
49
|
+
args: ['input', ['$event']]
|
|
50
|
+
}] } });
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3JwaWNrZXItdGV4dC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29sb3JwaWNrZXIvc3JjL2xpYi9tb2R1bGVzL2NvbG9ycGlja2VyL2NvbG9ycGlja2VyLXRleHQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLG1DQUFtQztBQUNuQyxPQUFPLEVBQ0wsU0FBUyxFQUNULFlBQVksRUFDWixZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQzs7QUFJdkI7O0dBRUc7QUFJSCxNQUFNLE9BQU8sMkJBQTJCO0lBSHhDO1FBS1MscUJBQWdCLEdBQUcsSUFBSSxZQUFZLEVBQTZCLENBQUM7S0FnQ3pFO0lBdkJRLFdBQVcsQ0FBQyxLQUFZO1FBQzdCLE1BQU0sT0FBTyxHQUFxQixLQUFLLENBQUMsTUFBMEIsQ0FBQztRQUNuRSxNQUFNLFlBQVksR0FBRyxVQUFVLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9DLElBQUksSUFBSSxDQUFDLFFBQVEsS0FBSyxTQUFTLEVBQUU7WUFDL0IsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQztnQkFDekIsS0FBSyxFQUFFLE9BQU8sQ0FBQyxLQUFLO2dCQUNwQixVQUFVLEVBQUUsU0FBUztnQkFDckIsUUFBUSxFQUFFLFNBQVM7YUFDUyxDQUFDLENBQUM7U0FDakM7UUFFRCxJQUNFLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQztZQUNwQixZQUFZLElBQUksQ0FBQztZQUNqQixZQUFZLElBQUksSUFBSSxDQUFDLFFBQVEsRUFDN0I7WUFDQSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDO2dCQUN6QixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7Z0JBQ2pCLFVBQVUsRUFBRSxZQUFZO2dCQUN4QixRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVE7YUFDSyxDQUFDLENBQUM7U0FDakM7SUFDSCxDQUFDOzt3SEFqQ1UsMkJBQTJCOzRHQUEzQiwyQkFBMkI7MkZBQTNCLDJCQUEyQjtrQkFIdkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsc0JBQXNCO2lCQUNqQzs4QkFHUSxnQkFBZ0I7c0JBRHRCLE1BQU07Z0JBR0Esa0JBQWtCO3NCQUR4QixLQUFLO2dCQUdDLEtBQUs7c0JBRFgsS0FBSztnQkFHQyxRQUFRO3NCQURkLEtBQUs7Z0JBSUMsV0FBVztzQkFEakIsWUFBWTt1QkFBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBzcGVsbC1jaGVja2VyOmlnbm9yZSBDb2xvcnBpY2tlclxuaW1wb3J0IHtcbiAgRGlyZWN0aXZlLFxuICBFdmVudEVtaXR0ZXIsXG4gIEhvc3RMaXN0ZW5lcixcbiAgSW5wdXQsXG4gIE91dHB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFNreUNvbG9ycGlja2VyQ2hhbmdlQ29sb3IgfSBmcm9tICcuL3R5cGVzL2NvbG9ycGlja2VyLWNvbG9yJztcblxuLyoqXG4gKiBAaW50ZXJuYWxcbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW3NreUNvbG9ycGlja2VyVGV4dF0nLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lDb2xvcnBpY2tlclRleHREaXJlY3RpdmUge1xuICBAT3V0cHV0KClcbiAgcHVibGljIG5ld0NvbG9yQ29udHJhc3QgPSBuZXcgRXZlbnRFbWl0dGVyPFNreUNvbG9ycGlja2VyQ2hhbmdlQ29sb3I+KCk7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBza3lDb2xvcnBpY2tlclRleHQ6IGFueTtcbiAgQElucHV0KClcbiAgcHVibGljIGNvbG9yOiBzdHJpbmc7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBtYXhSYW5nZTogbnVtYmVyO1xuXG4gIEBIb3N0TGlzdGVuZXIoJ2lucHV0JywgWyckZXZlbnQnXSlcbiAgcHVibGljIGNoYW5nZUlucHV0KGV2ZW50OiBFdmVudCkge1xuICAgIGNvbnN0IGVsZW1lbnQ6IEhUTUxJbnB1dEVsZW1lbnQgPSBldmVudC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudDtcbiAgICBjb25zdCBlbGVtZW50VmFsdWUgPSBwYXJzZUZsb2F0KGVsZW1lbnQudmFsdWUpO1xuICAgIGlmICh0aGlzLm1heFJhbmdlID09PSB1bmRlZmluZWQpIHtcbiAgICAgIHRoaXMubmV3Q29sb3JDb250cmFzdC5lbWl0KHtcbiAgICAgICAgY29sb3I6IGVsZW1lbnQudmFsdWUsXG4gICAgICAgIGNvbG9yVmFsdWU6IHVuZGVmaW5lZCxcbiAgICAgICAgbWF4UmFuZ2U6IHVuZGVmaW5lZCxcbiAgICAgIH0gYXMgU2t5Q29sb3JwaWNrZXJDaGFuZ2VDb2xvcik7XG4gICAgfVxuXG4gICAgaWYgKFxuICAgICAgIWlzTmFOKGVsZW1lbnRWYWx1ZSkgJiZcbiAgICAgIGVsZW1lbnRWYWx1ZSA+PSAwICYmXG4gICAgICBlbGVtZW50VmFsdWUgPD0gdGhpcy5tYXhSYW5nZVxuICAgICkge1xuICAgICAgdGhpcy5uZXdDb2xvckNvbnRyYXN0LmVtaXQoe1xuICAgICAgICBjb2xvcjogdGhpcy5jb2xvcixcbiAgICAgICAgY29sb3JWYWx1ZTogZWxlbWVudFZhbHVlLFxuICAgICAgICBtYXhSYW5nZTogdGhpcy5tYXhSYW5nZSxcbiAgICAgIH0gYXMgU2t5Q29sb3JwaWNrZXJDaGFuZ2VDb2xvcik7XG4gICAgfVxuICB9XG59XG4iXX0=
|