ngx-input-color
Version:
Angular color input component and color picker (with HSL, HSV, RGB, CMYK, HEX, alpha, eye-dropper, etc)
182 lines • 35.8 kB
JavaScript
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output, } from '@angular/core';
import { ColorFormats } from '../../models/ColorFormats.enum';
import { NgxColor } from '../../utils/color-helper';
import { NG_VALIDATORS, NG_VALUE_ACCESSOR, } from '@angular/forms';
import { ColorInspector } from '../../models/ColorInspector.enum';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@angular/forms";
import * as i3 from "../inspectors/picker/picker.component";
import * as i4 from "../inspectors/cmyk/cmyk.component";
import * as i5 from "../inspectors/hsl/hsl.component";
import * as i6 from "../inspectors/rgb/rgb.component";
import * as i7 from "../../pipes/enum-to-array.pipe";
export class NgxInputColorComponent {
set setTheme(val) {
if (!val || val == 'auto') {
this.theme = window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light';
}
else {
this.theme = val;
}
}
constructor(cd) {
this.cd = cd;
this.theme = 'auto';
/** Minifi UI */
this.simpleMode = false;
this.outputType = 'HEX';
/**
* default inspectors
* - ColorInspector.Picker
* - ColorInspector.RGB
* - ColorInspector.HSL
*
* @alias defaultInspector
*/
this.defaultInspector = ColorInspector.Picker;
/** Emitted when the color value changes */
this.change = new EventEmitter();
/** @ignore */
this.format = ColorFormats.HSVA;
/** @ignore */
this.isDarkColor = true;
/** @ignore */
this.rgbaColor = 'rgba(0, 0, 0, 1)';
/** @ignore */
this.hexColor = '#000000';
this.outputColor = '';
/** @ignore */
this.name = 'black';
/** @ignore */
this.color = new NgxColor();
/** @ignore */
this.isDisabled = false;
/**@ignore */
this._onChange = (value) => { };
/**@ignore */
this._onTouched = () => { };
/**@ignore */
this._onValidateChange = () => { };
this.isSupportedEyeDrop = 'EyeDropper' in window;
}
/** @ignore */
ngOnInit() {
if (this.theme == 'auto') {
this.theme = window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light';
}
}
/** @ignore */
ngOnDestroy() { }
get ColorFormats() {
return ColorFormats;
}
get ColorInspector() {
return ColorInspector;
}
/** @ignore */
registerOnChange(fn) {
this._onChange = fn;
}
/** @ignore */
registerOnTouched(fn) {
this._onTouched = fn;
}
/** @ignore */
setDisabledState(disabled) {
this.isDisabled = disabled;
}
/** @ignore */
registerOnValidatorChange(fn) {
this._onValidateChange = fn;
}
/** @ignore */
validate(control) {
if (this.color && this.color.isValid === false) {
return { invalid: true };
}
return null;
}
/** @ignore */
writeValue(value) {
try {
const c = value ? new NgxColor(value) : new NgxColor('#000');
this.initColor(c);
this._onValidateChange();
}
catch (e) {
const c = new NgxColor('#000'); // مقدار پیشفرض
this.initColor(c);
}
}
/** @ignore */
openEyeDrop() {
if (this.isSupportedEyeDrop) {
let t = new EyeDropper().open();
t.then(async (result) => {
this.hexColor = result.sRGBHex;
this.initColor(new NgxColor(this.hexColor));
this.cd.detectChanges();
});
}
}
/**
* call from directive
/* @ignore
*/
async initColor(c) {
if (!c)
return;
this.color = c;
this.rgbaColor = this.color.toRgbString();
this.hexColor = this.color.toHexString();
this.outputColor = await this.color.getOutputResult(this.outputType);
this.isDarkColor = this.color.isDark();
this.name = await this.color.name();
this.emitChange();
}
/** @ignore */
stopPropagation(ev) {
ev.stopPropagation();
}
/** @ignore */
async emitChange() {
this.outputColor = await this.color.getOutputResult(this.outputType);
this._onChange(this.outputColor);
this.change.emit(this.outputColor);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NgxInputColorComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: NgxInputColorComponent, selector: "ngx-input-color", inputs: { setTheme: ["theme", "setTheme"], simpleMode: "simpleMode", outputType: "outputType", defaultInspector: "defaultInspector" }, outputs: { change: "change" }, host: { properties: { "class.dark": "theme==\"dark\"" } }, providers: [
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NgxInputColorComponent), multi: true },
{
provide: NG_VALIDATORS,
multi: true,
useExisting: NgxInputColorComponent,
},
], ngImport: i0, template: "<div class=\"ngx-input-color-picker\" (click)=\"stopPropagation($event)\" [class.simple-mode]=\"simpleMode\">\r\n <div class=\"ngx-color-preview\" [style.background]=\"rgbaColor\" [class.is-dark-color]=\"isDarkColor\" *ngIf=\"!simpleMode\">\r\n <div class=\"rgbacode\">{{ outputColor | uppercase }}</div>\r\n <div class=\"hexacode\" *ngIf=\"outputType !== 'HEX'\">{{ hexColor | uppercase }}</div>\r\n <div class=\"colorname\">{{ name }}</div>\r\n <div class=\"color\"></div>\r\n </div>\r\n <div class=\"inner\">\r\n <div class=\"top-actions\">\r\n <select [(ngModel)]=\"defaultInspector\">\r\n <option *ngFor=\"let inspector of ColorInspector | enumToArray\" [value]=\"inspector\">\r\n {{ ColorInspector[+inspector] }}\r\n </option>\r\n </select>\r\n\r\n <button type=\"button\" (click)=\"openEyeDrop()\" class=\"ngx-btn-eyedroper\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 512 512\">\r\n <defs>\r\n <style>\r\n .fa-secondary {\r\n opacity: 0.4;\r\n }\r\n </style>\r\n </defs>\r\n <path\r\n class=\"fa-primary\"\r\n d=\"M482.8 29.23C521.7 68.21 521.7 131.4 482.8 170.4L381.2 271.9L390.6 281.4C403.1 293.9 403.1 314.1 390.6 326.6C378.1 339.1 357.9 339.1 345.4 326.6L185.4 166.6C172.9 154.1 172.9 133.9 185.4 121.4C197.9 108.9 218.1 108.9 230.6 121.4L240.1 130.8L341.6 29.23C380.6-9.744 443.8-9.744 482.8 29.23L482.8 29.23zM132.1 416H96V379.9C96 375.6 97.69 371.6 100.7 368.6L149.3 320H234.7L143.4 411.3C140.4 414.3 136.4 416 132.1 416H132.1z\" />\r\n <path\r\n class=\"fa-secondary\"\r\n d=\"M244 225.3L100.7 368.6C97.69 371.6 96 375.6 96 379.9V416H132.1C136.4 416 140.4 414.3 143.4 411.3L286.7 268L332 313.3L188.7 456.6C173.7 471.6 153.3 480 132.1 480H89.69L49.75 506.6C37.06 515.1 20.16 513.4 9.372 502.6C-1.414 491.8-3.087 474.9 5.374 462.2L32 422.3V379.9C32 358.7 40.43 338.3 55.43 323.3L198.7 180L244 225.3z\" />\r\n </svg>\r\n </button>\r\n </div>\r\n\r\n <ng-container [ngSwitch]=\"+defaultInspector\">\r\n <app-picker\r\n *ngSwitchCase=\"ColorInspector.Picker\"\r\n [color]=\"color\"\r\n (colorChange)=\"initColor($event)\"\r\n [simpleMode]=\"simpleMode\"></app-picker>\r\n <app-hsl *ngSwitchCase=\"ColorInspector.HSL\" [color]=\"color\" (colorChange)=\"initColor($event)\"></app-hsl>\r\n <app-rgb *ngSwitchCase=\"ColorInspector.RGB\" [color]=\"color\" (colorChange)=\"initColor($event)\"></app-rgb>\r\n <app-cmyk *ngSwitchCase=\"ColorInspector.CMYK\" [color]=\"color\" (colorChange)=\"initColor($event)\"></app-cmyk>\r\n </ng-container>\r\n </div>\r\n</div>\r\n", styles: [":host{--ngx-color-bg: #fff;--ngx-color-text: #000}:host-context(.dark){--ngx-color-bg: #222;--ngx-color-text: #fff}.ngx-input-color-picker{width:270px;max-width:100%;border:1px #bfbfbf solid;border-radius:15px;background:var(--ngx-color-bg);color:var(--ngx-color-text);overflow:hidden;box-shadow:0 0 20px #0000004f;direction:ltr;font-family:arial,tahoma}.ngx-input-color-picker .inner{padding:0 12px 12px}.ngx-input-color-picker *{box-sizing:border-box}.ngx-input-color-picker.simple-mode{width:220px;--ngx-thumb-size: 24px}.ngx-input-color-picker.simple-mode .inner{padding:12px}.ngx-color-preview{min-height:100px;padding:10px 36px;line-height:1.6;font-size:14px;font-family:arial,tahoma;font-weight:700;position:relative;color:#353535}.ngx-color-preview.is-dark-color{color:#fff}.ngx-color-preview:after{content:\" \";position:absolute;background-color:var(--ngx-color-bg);bottom:0;width:100%;left:0;right:0;height:15px;border-radius:18px 18px 0 0}.ngx-color-preview:before{content:\" \";background-image:linear-gradient(45deg,#ccc 25%,transparent 25%),linear-gradient(-45deg,#ccc 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#ccc 75%),linear-gradient(-45deg,transparent 75%,#ccc 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0px;position:absolute;inset:0;z-index:-1}.button-groups{display:flex;border-radius:4px;overflow:hidden;border:1px #d3d3d3 solid}.button-groups button{cursor:pointer;background:#f9f9f9;outline:none;border:none;transition:all .3s;border-left:1px #d3d3d3 solid;padding:10px 12px;flex:auto}.button-groups button:hover{background:#8db6e4}.button-groups button:first-child{border-left-width:0}.ngx-btn-eyedroper{padding:2px;min-width:0;width:45px;cursor:pointer;background-color:transparent;outline:none;transition:all .3s;border:none;border-radius:6px}.ngx-btn-eyedroper svg{width:18px;fill:var(--ngx-color-text)}.top-actions{display:flex;justify-content:space-between;align-items:center;padding:0 0 12px}.top-actions select{outline:none;border:none;border-radius:4px;padding:5px 10px;background:none;color:var(--ngx-color-text)}.top-actions select:focus{cursor:pointer;background:#e5f0ff;color:#06f}.top-actions select option{padding:10px 20px;background:var(--ngx-color-bg);color:var(--ngx-color-text);transition:all .3s}.top-actions select option:hover{background:#f0f0f048}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.PickerComponent, selector: "app-picker", inputs: ["simpleMode", "color"], outputs: ["colorChange"] }, { kind: "component", type: i4.CmykComponent, selector: "app-cmyk", inputs: ["color"], outputs: ["colorChange"] }, { kind: "component", type: i5.HslComponent, selector: "app-hsl", inputs: ["color"], outputs: ["colorChange"] }, { kind: "component", type: i6.RgbComponent, selector: "app-rgb", inputs: ["color"], outputs: ["colorChange"] }, { kind: "pipe", type: i1.UpperCasePipe, name: "uppercase" }, { kind: "pipe", type: i7.EnumToArrayPipe, name: "enumToArray" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NgxInputColorComponent, decorators: [{
type: Component,
args: [{ selector: 'ngx-input-color', providers: [
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NgxInputColorComponent), multi: true },
{
provide: NG_VALIDATORS,
multi: true,
useExisting: NgxInputColorComponent,
},
], changeDetection: ChangeDetectionStrategy.OnPush, host: {
'[class.dark]': 'theme=="dark"',
}, template: "<div class=\"ngx-input-color-picker\" (click)=\"stopPropagation($event)\" [class.simple-mode]=\"simpleMode\">\r\n <div class=\"ngx-color-preview\" [style.background]=\"rgbaColor\" [class.is-dark-color]=\"isDarkColor\" *ngIf=\"!simpleMode\">\r\n <div class=\"rgbacode\">{{ outputColor | uppercase }}</div>\r\n <div class=\"hexacode\" *ngIf=\"outputType !== 'HEX'\">{{ hexColor | uppercase }}</div>\r\n <div class=\"colorname\">{{ name }}</div>\r\n <div class=\"color\"></div>\r\n </div>\r\n <div class=\"inner\">\r\n <div class=\"top-actions\">\r\n <select [(ngModel)]=\"defaultInspector\">\r\n <option *ngFor=\"let inspector of ColorInspector | enumToArray\" [value]=\"inspector\">\r\n {{ ColorInspector[+inspector] }}\r\n </option>\r\n </select>\r\n\r\n <button type=\"button\" (click)=\"openEyeDrop()\" class=\"ngx-btn-eyedroper\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 512 512\">\r\n <defs>\r\n <style>\r\n .fa-secondary {\r\n opacity: 0.4;\r\n }\r\n </style>\r\n </defs>\r\n <path\r\n class=\"fa-primary\"\r\n d=\"M482.8 29.23C521.7 68.21 521.7 131.4 482.8 170.4L381.2 271.9L390.6 281.4C403.1 293.9 403.1 314.1 390.6 326.6C378.1 339.1 357.9 339.1 345.4 326.6L185.4 166.6C172.9 154.1 172.9 133.9 185.4 121.4C197.9 108.9 218.1 108.9 230.6 121.4L240.1 130.8L341.6 29.23C380.6-9.744 443.8-9.744 482.8 29.23L482.8 29.23zM132.1 416H96V379.9C96 375.6 97.69 371.6 100.7 368.6L149.3 320H234.7L143.4 411.3C140.4 414.3 136.4 416 132.1 416H132.1z\" />\r\n <path\r\n class=\"fa-secondary\"\r\n d=\"M244 225.3L100.7 368.6C97.69 371.6 96 375.6 96 379.9V416H132.1C136.4 416 140.4 414.3 143.4 411.3L286.7 268L332 313.3L188.7 456.6C173.7 471.6 153.3 480 132.1 480H89.69L49.75 506.6C37.06 515.1 20.16 513.4 9.372 502.6C-1.414 491.8-3.087 474.9 5.374 462.2L32 422.3V379.9C32 358.7 40.43 338.3 55.43 323.3L198.7 180L244 225.3z\" />\r\n </svg>\r\n </button>\r\n </div>\r\n\r\n <ng-container [ngSwitch]=\"+defaultInspector\">\r\n <app-picker\r\n *ngSwitchCase=\"ColorInspector.Picker\"\r\n [color]=\"color\"\r\n (colorChange)=\"initColor($event)\"\r\n [simpleMode]=\"simpleMode\"></app-picker>\r\n <app-hsl *ngSwitchCase=\"ColorInspector.HSL\" [color]=\"color\" (colorChange)=\"initColor($event)\"></app-hsl>\r\n <app-rgb *ngSwitchCase=\"ColorInspector.RGB\" [color]=\"color\" (colorChange)=\"initColor($event)\"></app-rgb>\r\n <app-cmyk *ngSwitchCase=\"ColorInspector.CMYK\" [color]=\"color\" (colorChange)=\"initColor($event)\"></app-cmyk>\r\n </ng-container>\r\n </div>\r\n</div>\r\n", styles: [":host{--ngx-color-bg: #fff;--ngx-color-text: #000}:host-context(.dark){--ngx-color-bg: #222;--ngx-color-text: #fff}.ngx-input-color-picker{width:270px;max-width:100%;border:1px #bfbfbf solid;border-radius:15px;background:var(--ngx-color-bg);color:var(--ngx-color-text);overflow:hidden;box-shadow:0 0 20px #0000004f;direction:ltr;font-family:arial,tahoma}.ngx-input-color-picker .inner{padding:0 12px 12px}.ngx-input-color-picker *{box-sizing:border-box}.ngx-input-color-picker.simple-mode{width:220px;--ngx-thumb-size: 24px}.ngx-input-color-picker.simple-mode .inner{padding:12px}.ngx-color-preview{min-height:100px;padding:10px 36px;line-height:1.6;font-size:14px;font-family:arial,tahoma;font-weight:700;position:relative;color:#353535}.ngx-color-preview.is-dark-color{color:#fff}.ngx-color-preview:after{content:\" \";position:absolute;background-color:var(--ngx-color-bg);bottom:0;width:100%;left:0;right:0;height:15px;border-radius:18px 18px 0 0}.ngx-color-preview:before{content:\" \";background-image:linear-gradient(45deg,#ccc 25%,transparent 25%),linear-gradient(-45deg,#ccc 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#ccc 75%),linear-gradient(-45deg,transparent 75%,#ccc 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0px;position:absolute;inset:0;z-index:-1}.button-groups{display:flex;border-radius:4px;overflow:hidden;border:1px #d3d3d3 solid}.button-groups button{cursor:pointer;background:#f9f9f9;outline:none;border:none;transition:all .3s;border-left:1px #d3d3d3 solid;padding:10px 12px;flex:auto}.button-groups button:hover{background:#8db6e4}.button-groups button:first-child{border-left-width:0}.ngx-btn-eyedroper{padding:2px;min-width:0;width:45px;cursor:pointer;background-color:transparent;outline:none;transition:all .3s;border:none;border-radius:6px}.ngx-btn-eyedroper svg{width:18px;fill:var(--ngx-color-text)}.top-actions{display:flex;justify-content:space-between;align-items:center;padding:0 0 12px}.top-actions select{outline:none;border:none;border-radius:4px;padding:5px 10px;background:none;color:var(--ngx-color-text)}.top-actions select:focus{cursor:pointer;background:#e5f0ff;color:#06f}.top-actions select option{padding:10px 20px;background:var(--ngx-color-bg);color:var(--ngx-color-text);transition:all .3s}.top-actions select option:hover{background:#f0f0f048}\n"] }]
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { setTheme: [{
type: Input,
args: ['theme']
}], simpleMode: [{
type: Input
}], outputType: [{
type: Input
}], defaultInspector: [{
type: Input
}], change: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-input-color.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-input-color/src/lib/ngx-input-color/ngx-input-color.component.ts","../../../../../projects/ngx-input-color/src/lib/ngx-input-color/ngx-input-color.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { ColorFormats } from '../../models/ColorFormats.enum';\r\nimport { NgxColor, OutputType } from '../../utils/color-helper';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  NG_VALIDATORS,\r\n  NG_VALUE_ACCESSOR,\r\n  ValidationErrors,\r\n  Validator,\r\n} from '@angular/forms';\r\nimport { ColorInspector } from '../../models/ColorInspector.enum';\r\ndeclare const EyeDropper: any;\r\n@Component({\r\n  selector: 'ngx-input-color',\r\n  templateUrl: './ngx-input-color.component.html',\r\n  styleUrls: ['./ngx-input-color.component.scss'],\r\n  providers: [\r\n    { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NgxInputColorComponent), multi: true },\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      multi: true,\r\n      useExisting: NgxInputColorComponent,\r\n    },\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  host: {\r\n    '[class.dark]': 'theme==\"dark\"',\r\n  },\r\n})\r\nexport class NgxInputColorComponent implements OnInit, OnDestroy, ControlValueAccessor, Validator {\r\n  theme: 'light' | 'dark' | 'auto' = 'auto';\r\n  @Input('theme') set setTheme(val: 'light' | 'dark' | 'auto') {\r\n    if (!val || val == 'auto') {\r\n      this.theme = window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light';\r\n    } else {\r\n      this.theme = val;\r\n    }\r\n  }\r\n\r\n  /** Minifi UI  */\r\n  @Input() simpleMode = false;\r\n\r\n  @Input() outputType: OutputType = 'HEX';\r\n\r\n  /**\r\n   * default inspectors\r\n   * - ColorInspector.Picker\r\n   * - ColorInspector.RGB\r\n   * - ColorInspector.HSL\r\n   *\r\n   * @alias defaultInspector\r\n   */\r\n  @Input() defaultInspector: ColorInspector = ColorInspector.Picker;\r\n\r\n  /** Emitted when the color value changes */\r\n  @Output() change = new EventEmitter<string>();\r\n\r\n  /** @ignore */\r\n  format: ColorFormats = ColorFormats.HSVA;\r\n  /** @ignore */\r\n  isDarkColor = true;\r\n\r\n  /** @ignore */\r\n  rgbaColor = 'rgba(0, 0, 0, 1)';\r\n  /** @ignore */\r\n  hexColor = '#000000';\r\n  outputColor = '';\r\n\r\n  /** @ignore */\r\n  name = 'black';\r\n\r\n  /** @ignore */\r\n  isSupportedEyeDrop: boolean;\r\n\r\n  /** @ignore */\r\n  color: NgxColor = new NgxColor();\r\n\r\n  /** @ignore */\r\n  isDisabled = false;\r\n  /**@ignore */\r\n  private _onChange = (value: string) => {};\r\n  /**@ignore */\r\n  private _onTouched = () => {};\r\n  /**@ignore */\r\n  private _onValidateChange = () => {};\r\n  constructor(private cd: ChangeDetectorRef) {\r\n    this.isSupportedEyeDrop = 'EyeDropper' in window;\r\n  }\r\n\r\n  /** @ignore */\r\n  ngOnInit(): void {\r\n    if (this.theme == 'auto') {\r\n      this.theme = window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light';\r\n    }\r\n  }\r\n  /** @ignore */\r\n  ngOnDestroy(): void {}\r\n  public get ColorFormats(): typeof ColorFormats {\r\n    return ColorFormats;\r\n  }\r\n  public get ColorInspector(): typeof ColorInspector {\r\n    return ColorInspector;\r\n  }\r\n  /** @ignore */\r\n  registerOnChange(fn: any): void {\r\n    this._onChange = fn;\r\n  }\r\n  /** @ignore */\r\n  registerOnTouched(fn: any): void {\r\n    this._onTouched = fn;\r\n  }\r\n  /** @ignore */\r\n  setDisabledState(disabled: boolean): void {\r\n    this.isDisabled = disabled;\r\n  }\r\n  /** @ignore */\r\n  registerOnValidatorChange(fn: () => void): void {\r\n    this._onValidateChange = fn;\r\n  }\r\n  /** @ignore */\r\n  validate(control: AbstractControl): ValidationErrors | null {\r\n    if (this.color && this.color.isValid === false) {\r\n      return { invalid: true };\r\n    }\r\n    return null;\r\n  }\r\n\r\n  /** @ignore */\r\n  writeValue(value: any): void {\r\n    try {\r\n      const c = value ? new NgxColor(value) : new NgxColor('#000');\r\n      this.initColor(c);\r\n      this._onValidateChange();\r\n    } catch (e) {\r\n      const c = new NgxColor('#000'); // مقدار پیش‌فرض\r\n      this.initColor(c);\r\n    }\r\n  }\r\n  /** @ignore */\r\n  openEyeDrop() {\r\n    if (this.isSupportedEyeDrop) {\r\n      let t = new EyeDropper().open();\r\n      t.then(async (result: { sRGBHex: string }) => {\r\n        this.hexColor = result.sRGBHex;\r\n        this.initColor(new NgxColor(this.hexColor));\r\n        this.cd.detectChanges();\r\n      });\r\n    }\r\n  }\r\n\r\n  /**\r\n   *  call from directive\r\n  /* @ignore \r\n   */\r\n  async initColor(c?: NgxColor) {\r\n    if (!c) return;\r\n    this.color = c;\r\n    this.rgbaColor = this.color.toRgbString();\r\n    this.hexColor = this.color.toHexString();\r\n    this.outputColor = await this.color.getOutputResult(this.outputType);\r\n    this.isDarkColor = this.color.isDark();\r\n    this.name = await this.color.name();\r\n    this.emitChange();\r\n  }\r\n\r\n  /** @ignore */\r\n  stopPropagation(ev: Event) {\r\n    ev.stopPropagation();\r\n  }\r\n\r\n  /** @ignore */\r\n  async emitChange() {\r\n    this.outputColor = await this.color.getOutputResult(this.outputType);\r\n    this._onChange(this.outputColor);\r\n    this.change.emit(this.outputColor);\r\n  }\r\n}\r\n","<div class=\"ngx-input-color-picker\" (click)=\"stopPropagation($event)\" [class.simple-mode]=\"simpleMode\">\r\n  <div class=\"ngx-color-preview\" [style.background]=\"rgbaColor\" [class.is-dark-color]=\"isDarkColor\" *ngIf=\"!simpleMode\">\r\n    <div class=\"rgbacode\">{{ outputColor | uppercase }}</div>\r\n    <div class=\"hexacode\" *ngIf=\"outputType !== 'HEX'\">{{ hexColor | uppercase }}</div>\r\n    <div class=\"colorname\">{{ name }}</div>\r\n    <div class=\"color\"></div>\r\n  </div>\r\n  <div class=\"inner\">\r\n    <div class=\"top-actions\">\r\n      <select [(ngModel)]=\"defaultInspector\">\r\n        <option *ngFor=\"let inspector of ColorInspector | enumToArray\" [value]=\"inspector\">\r\n          {{ ColorInspector[+inspector] }}\r\n        </option>\r\n      </select>\r\n\r\n      <button type=\"button\" (click)=\"openEyeDrop()\" class=\"ngx-btn-eyedroper\">\r\n        <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 512 512\">\r\n          <defs>\r\n            <style>\r\n              .fa-secondary {\r\n                opacity: 0.4;\r\n              }\r\n            </style>\r\n          </defs>\r\n          <path\r\n            class=\"fa-primary\"\r\n            d=\"M482.8 29.23C521.7 68.21 521.7 131.4 482.8 170.4L381.2 271.9L390.6 281.4C403.1 293.9 403.1 314.1 390.6 326.6C378.1 339.1 357.9 339.1 345.4 326.6L185.4 166.6C172.9 154.1 172.9 133.9 185.4 121.4C197.9 108.9 218.1 108.9 230.6 121.4L240.1 130.8L341.6 29.23C380.6-9.744 443.8-9.744 482.8 29.23L482.8 29.23zM132.1 416H96V379.9C96 375.6 97.69 371.6 100.7 368.6L149.3 320H234.7L143.4 411.3C140.4 414.3 136.4 416 132.1 416H132.1z\" />\r\n          <path\r\n            class=\"fa-secondary\"\r\n            d=\"M244 225.3L100.7 368.6C97.69 371.6 96 375.6 96 379.9V416H132.1C136.4 416 140.4 414.3 143.4 411.3L286.7 268L332 313.3L188.7 456.6C173.7 471.6 153.3 480 132.1 480H89.69L49.75 506.6C37.06 515.1 20.16 513.4 9.372 502.6C-1.414 491.8-3.087 474.9 5.374 462.2L32 422.3V379.9C32 358.7 40.43 338.3 55.43 323.3L198.7 180L244 225.3z\" />\r\n        </svg>\r\n      </button>\r\n    </div>\r\n\r\n    <ng-container [ngSwitch]=\"+defaultInspector\">\r\n      <app-picker\r\n        *ngSwitchCase=\"ColorInspector.Picker\"\r\n        [color]=\"color\"\r\n        (colorChange)=\"initColor($event)\"\r\n        [simpleMode]=\"simpleMode\"></app-picker>\r\n      <app-hsl *ngSwitchCase=\"ColorInspector.HSL\" [color]=\"color\" (colorChange)=\"initColor($event)\"></app-hsl>\r\n      <app-rgb *ngSwitchCase=\"ColorInspector.RGB\" [color]=\"color\" (colorChange)=\"initColor($event)\"></app-rgb>\r\n      <app-cmyk *ngSwitchCase=\"ColorInspector.CMYK\" [color]=\"color\" (colorChange)=\"initColor($event)\"></app-cmyk>\r\n    </ng-container>\r\n  </div>\r\n</div>\r\n"]}