import { Directive, Input, Output, EventEmitter, HostListener, Injector } from '@angular/core'; import { ColorPickerComponent } from './color-picker.component'; import * as i0 from "@angular/core"; import * as i1 from "./color-picker.service"; // Caretaker note: we have still left the `typeof` condition in order to avoid // creating a breaking change for projects that still use the View Engine. // The `ngDevMode` is always available when Ivy is enabled. // This will be evaluated during compilation into `const NG_DEV_MODE = false`, // thus Terser will be able to tree-shake `console.warn` calls. const NG_DEV_MODE = typeof ngDevMode === 'undefined' || !!ngDevMode; export class ColorPickerDirective { injector; cfr; appRef; vcRef; elRef; _service; dialog; dialogCreated = false; ignoreChanges = false; cmpRef; viewAttachedToAppRef = false; colorPicker; cpWidth = '230px'; cpHeight = 'auto'; cpToggle = false; cpDisabled = false; cpIgnoredElements = []; cpFallbackColor = ''; cpColorMode = 'color'; cpCmykEnabled = false; cpOutputFormat = 'auto'; cpAlphaChannel = 'enabled'; cpDisableInput = false; cpDialogDisplay = 'popup'; cpSaveClickOutside = true; cpCloseClickOutside = true; cpUseRootViewContainer = false; cpPosition = 'auto'; cpPositionOffset = '0%'; cpPositionRelativeToArrow = false; cpOKButton = false; cpOKButtonText = 'OK'; cpOKButtonClass = 'cp-ok-button-class'; cpCancelButton = false; cpCancelButtonText = 'Cancel'; cpCancelButtonClass = 'cp-cancel-button-class'; cpEyeDropper = false; cpPresetLabel = 'Preset colors'; cpPresetColors; cpPresetColorsClass = 'cp-preset-colors-class'; cpMaxPresetColorsLength = 6; cpPresetEmptyMessage = 'No colors added'; cpPresetEmptyMessageClass = 'preset-empty-message'; cpAddColorButton = false; cpAddColorButtonText = 'Add color'; cpAddColorButtonClass = 'cp-add-color-button-class'; cpRemoveColorButtonClass = 'cp-remove-color-button-class'; cpArrowPosition = 0; cpExtraTemplate; cpInputChange = new EventEmitter(true); cpToggleChange = new EventEmitter(true); cpSliderChange = new EventEmitter(true); cpSliderDragEnd = new EventEmitter(true); cpSliderDragStart = new EventEmitter(true); colorPickerOpen = new EventEmitter(true); colorPickerClose = new EventEmitter(true); colorPickerCancel = new EventEmitter(true); colorPickerSelect = new EventEmitter(true); colorPickerChange = new EventEmitter(false); cpCmykColorChange = new EventEmitter(true); cpPresetColorsChange = new EventEmitter(true); handleClick() { this.inputFocus(); } handleFocus() { this.inputFocus(); } handleInput(event) { this.inputChange(event); } constructor(injector, cfr, appRef, vcRef, elRef, _service) { this.injector = injector; this.cfr = cfr; this.appRef = appRef; this.vcRef = vcRef; this.elRef = elRef; this._service = _service; } ngOnDestroy() { if (this.cmpRef != null) { if (this.viewAttachedToAppRef) { this.appRef.detachView(this.cmpRef.hostView); } this.cmpRef.destroy(); this.cmpRef = null; this.dialog = null; } } ngOnChanges(changes) { if (changes.cpToggle && !this.cpDisabled) { if (changes.cpToggle.currentValue) { this.openDialog(); } else if (!changes.cpToggle.currentValue) { this.closeDialog(); } } if (changes.colorPicker) { if (this.dialog && !this.ignoreChanges) { if (this.cpDialogDisplay === 'inline') { this.dialog.setInitialColor(changes.colorPicker.currentValue); } this.dialog.setColorFromString(changes.colorPicker.currentValue, false); if (this.cpUseRootViewContainer && this.cpDialogDisplay !== 'inline') { this.cmpRef.changeDetectorRef.detectChanges(); } } this.ignoreChanges = false; } if (changes.cpPresetLabel || changes.cpPresetColors) { if (this.dialog) { this.dialog.setPresetConfig(this.cpPresetLabel, this.cpPresetColors); } } } openDialog() { if (!this.dialogCreated) { let vcRef = this.vcRef; this.dialogCreated = true; this.viewAttachedToAppRef = false; if (this.cpUseRootViewContainer && this.cpDialogDisplay !== 'inline') { const classOfRootComponent = this.appRef.componentTypes[0]; const appInstance = this.injector.get(classOfRootComponent, Injector.NULL); if (appInstance !== Injector.NULL) { vcRef = appInstance.vcRef || appInstance.viewContainerRef || this.vcRef; if (NG_DEV_MODE && vcRef === this.vcRef) { console.warn('You are using cpUseRootViewContainer, ' + 'but the root component is not exposing viewContainerRef!' + 'Please expose it by adding \'public vcRef: ViewContainerRef\' to the constructor.'); } } else { this.viewAttachedToAppRef = true; } } const compFactory = this.cfr.resolveComponentFactory(ColorPickerComponent); if (this.viewAttachedToAppRef) { this.cmpRef = compFactory.create(this.injector); this.appRef.attachView(this.cmpRef.hostView); document.body.appendChild(this.cmpRef.hostView.rootNodes[0]); } else { const injector = Injector.create({ providers: [], // We shouldn't use `vcRef.parentInjector` since it's been deprecated long time ago and might be removed // in newer Angular versions: https://github.com/angular/angular/pull/25174. parent: vcRef.injector, }); this.cmpRef = vcRef.createComponent(compFactory, 0, injector, []); } this.cmpRef.instance.setupDialog(this, this.elRef, this.colorPicker, this.cpWidth, this.cpHeight, this.cpDialogDisplay, this.cpFallbackColor, this.cpColorMode, this.cpCmykEnabled, this.cpAlphaChannel, this.cpOutputFormat, this.cpDisableInput, this.cpIgnoredElements, this.cpSaveClickOutside, this.cpCloseClickOutside, this.cpUseRootViewContainer, this.cpPosition, this.cpPositionOffset, this.cpPositionRelativeToArrow, this.cpPresetLabel, this.cpPresetColors, this.cpPresetColorsClass, this.cpMaxPresetColorsLength, this.cpPresetEmptyMessage, this.cpPresetEmptyMessageClass, this.cpOKButton, this.cpOKButtonClass, this.cpOKButtonText, this.cpCancelButton, this.cpCancelButtonClass, this.cpCancelButtonText, this.cpAddColorButton, this.cpAddColorButtonClass, this.cpAddColorButtonText, this.cpRemoveColorButtonClass, this.cpEyeDropper, this.elRef, this.cpExtraTemplate); this.dialog = this.cmpRef.instance; if (this.vcRef !== vcRef) { this.cmpRef.changeDetectorRef.detectChanges(); } } else if (this.dialog) { this.dialog.openDialog(this.colorPicker); } } closeDialog() { if (this.dialog && this.cpDialogDisplay === 'popup') { this.dialog.closeDialog(); } } cmykChanged(value) { this.cpCmykColorChange.emit(value); } stateChanged(state) { this.cpToggleChange.emit(state); if (state) { this.colorPickerOpen.emit(this.colorPicker); } else { this.colorPickerClose.emit(this.colorPicker); } } colorChanged(value, ignore = true) { this.ignoreChanges = ignore; this.colorPickerChange.emit(value); } colorSelected(value) { this.colorPickerSelect.emit(value); } colorCanceled() { this.colorPickerCancel.emit(); } inputFocus() { const element = this.elRef.nativeElement; const ignored = this.cpIgnoredElements.filter((item) => item === element); if (!this.cpDisabled && !ignored.length) { if (typeof document !== 'undefined' && element === document.activeElement) { this.openDialog(); } else if (!this.dialog || !this.dialog.show) { this.openDialog(); } else { this.closeDialog(); } } } inputChange(event) { if (this.dialog) { this.dialog.setColorFromString(event.target.value, true); } else { this.colorPicker = event.target.value; this.colorPickerChange.emit(this.colorPicker); } } inputChanged(event) { this.cpInputChange.emit(event); } sliderChanged(event) { this.cpSliderChange.emit(event); } sliderDragEnd(event) { this.cpSliderDragEnd.emit(event); } sliderDragStart(event) { this.cpSliderDragStart.emit(event); } presetColorsChanged(value) { this.cpPresetColorsChange.emit(value); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: ColorPickerDirective, deps: [{ token: i0.Injector }, { token: i0.ComponentFactoryResolver }, { token: i0.ApplicationRef }, { token: i0.ViewContainerRef }, { token: i0.ElementRef }, { token: i1.ColorPickerService }], target: i0.ɵɵFactoryTarget.Directive }); static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.5", type: ColorPickerDirective, selector: "[colorPicker]", inputs: { colorPicker: "colorPicker", cpWidth: "cpWidth", cpHeight: "cpHeight", cpToggle: "cpToggle", cpDisabled: "cpDisabled", cpIgnoredElements: "cpIgnoredElements", cpFallbackColor: "cpFallbackColor", cpColorMode: "cpColorMode", cpCmykEnabled: "cpCmykEnabled", cpOutputFormat: "cpOutputFormat", cpAlphaChannel: "cpAlphaChannel", cpDisableInput: "cpDisableInput", cpDialogDisplay: "cpDialogDisplay", cpSaveClickOutside: "cpSaveClickOutside", cpCloseClickOutside: "cpCloseClickOutside", cpUseRootViewContainer: "cpUseRootViewContainer", cpPosition: "cpPosition", cpPositionOffset: "cpPositionOffset", cpPositionRelativeToArrow: "cpPositionRelativeToArrow", cpOKButton: "cpOKButton", cpOKButtonText: "cpOKButtonText", cpOKButtonClass: "cpOKButtonClass", cpCancelButton: "cpCancelButton", cpCancelButtonText: "cpCancelButtonText", cpCancelButtonClass: "cpCancelButtonClass", cpEyeDropper: "cpEyeDropper", cpPresetLabel: "cpPresetLabel", cpPresetColors: "cpPresetColors", cpPresetColorsClass: "cpPresetColorsClass", cpMaxPresetColorsLength: "cpMaxPresetColorsLength", cpPresetEmptyMessage: "cpPresetEmptyMessage", cpPresetEmptyMessageClass: "cpPresetEmptyMessageClass", cpAddColorButton: "cpAddColorButton", cpAddColorButtonText: "cpAddColorButtonText", cpAddColorButtonClass: "cpAddColorButtonClass", cpRemoveColorButtonClass: "cpRemoveColorButtonClass", cpArrowPosition: "cpArrowPosition", cpExtraTemplate: "cpExtraTemplate" }, outputs: { cpInputChange: "cpInputChange", cpToggleChange: "cpToggleChange", cpSliderChange: "cpSliderChange", cpSliderDragEnd: "cpSliderDragEnd", cpSliderDragStart: "cpSliderDragStart", colorPickerOpen: "colorPickerOpen", colorPickerClose: "colorPickerClose", colorPickerCancel: "colorPickerCancel", colorPickerSelect: "colorPickerSelect", colorPickerChange: "colorPickerChange", cpCmykColorChange: "cpCmykColorChange", cpPresetColorsChange: "cpPresetColorsChange" }, host: { listeners: { "click": "handleClick()", "focus": "handleFocus()", "input": "handleInput($event)" } }, exportAs: ["ngxColorPicker"], usesOnChanges: true, ngImport: i0 }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: ColorPickerDirective, decorators: [{ type: Directive, args: [{ selector: '[colorPicker]', exportAs: 'ngxColorPicker' }] }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i0.ComponentFactoryResolver }, { type: i0.ApplicationRef }, { type: i0.ViewContainerRef }, { type: i0.ElementRef }, { type: i1.ColorPickerService }]; }, propDecorators: { colorPicker: [{ type: Input }], cpWidth: [{ type: Input }], cpHeight: [{ type: Input }], cpToggle: [{ type: Input }], cpDisabled: [{ type: Input }], cpIgnoredElements: [{ type: Input }], cpFallbackColor: [{ type: Input }], cpColorMode: [{ type: Input }], cpCmykEnabled: [{ type: Input }], cpOutputFormat: [{ type: Input }], cpAlphaChannel: [{ type: Input }], cpDisableInput: [{ type: Input }], cpDialogDisplay: [{ type: Input }], cpSaveClickOutside: [{ type: Input }], cpCloseClickOutside: [{ type: Input }], cpUseRootViewContainer: [{ type: Input }], cpPosition: [{ type: Input }], cpPositionOffset: [{ type: Input }], cpPositionRelativeToArrow: [{ type: Input }], cpOKButton: [{ type: Input }], cpOKButtonText: [{ type: Input }], cpOKButtonClass: [{ type: Input }], cpCancelButton: [{ type: Input }], cpCancelButtonText: [{ type: Input }], cpCancelButtonClass: [{ type: Input }], cpEyeDropper: [{ type: Input }], cpPresetLabel: [{ type: Input }], cpPresetColors: [{ type: Input }], cpPresetColorsClass: [{ type: Input }], cpMaxPresetColorsLength: [{ type: Input }], cpPresetEmptyMessage: [{ type: Input }], cpPresetEmptyMessageClass: [{ type: Input }], cpAddColorButton: [{ type: Input }], cpAddColorButtonText: [{ type: Input }], cpAddColorButtonClass: [{ type: Input }], cpRemoveColorButtonClass: [{ type: Input }], cpArrowPosition: [{ type: Input }], cpExtraTemplate: [{ type: Input }], cpInputChange: [{ type: Output }], cpToggleChange: [{ type: Output }], cpSliderChange: [{ type: Output }], cpSliderDragEnd: [{ type: Output }], cpSliderDragStart: [{ type: Output }], colorPickerOpen: [{ type: Output }], colorPickerClose: [{ type: Output }], colorPickerCancel: [{ type: Output }], colorPickerSelect: [{ type: Output }], colorPickerChange: [{ type: Output }], cpCmykColorChange: [{ type: Output }], cpPresetColorsChange: [{ type: Output }], handleClick: [{ type: HostListener, args: ['click'] }], handleFocus: [{ type: HostListener, args: ['focus'] }], handleInput: [{ type: HostListener, args: ['input', ['$event']] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.directive.js","sourceRoot":"","sources":["../../../../projects/lib/src/lib/color-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, OnChanges, OnDestroy, Input, Output, EventEmitter,\n  HostListener, ApplicationRef, ComponentRef, ElementRef, ViewContainerRef,\n  Injector, ComponentFactoryResolver, EmbeddedViewRef, TemplateRef } from '@angular/core';\n\nimport { ColorPickerService } from './color-picker.service';\nimport { ColorPickerComponent } from './color-picker.component';\n\nimport { AlphaChannel, ColorMode, OutputFormat } from './helpers';\n\n// Caretaker note: we have still left the `typeof` condition in order to avoid\n// creating a breaking change for projects that still use the View Engine.\n// The `ngDevMode` is always available when Ivy is enabled.\n// This will be evaluated during compilation into `const NG_DEV_MODE = false`,\n// thus Terser will be able to tree-shake `console.warn` calls.\nconst NG_DEV_MODE = typeof ngDevMode === 'undefined' || !!ngDevMode;\n\n@Directive({\n  selector: '[colorPicker]',\n  exportAs: 'ngxColorPicker'\n})\nexport class ColorPickerDirective implements OnChanges, OnDestroy {\n  private dialog: any;\n\n  private dialogCreated: boolean = false;\n  private ignoreChanges: boolean = false;\n\n  private cmpRef: ComponentRef<ColorPickerComponent>;\n  private viewAttachedToAppRef: boolean = false;\n\n  @Input() colorPicker: string;\n\n  @Input() cpWidth: string = '230px';\n  @Input() cpHeight: string = 'auto';\n\n  @Input() cpToggle: boolean = false;\n  @Input() cpDisabled: boolean = false;\n\n  @Input() cpIgnoredElements: any = [];\n\n  @Input() cpFallbackColor: string = '';\n\n  @Input() cpColorMode: ColorMode = 'color';\n\n  @Input() cpCmykEnabled: boolean = false;\n\n  @Input() cpOutputFormat: OutputFormat = 'auto';\n  @Input() cpAlphaChannel: AlphaChannel = 'enabled';\n\n  @Input() cpDisableInput: boolean = false;\n\n  @Input() cpDialogDisplay: string = 'popup';\n\n  @Input() cpSaveClickOutside: boolean = true;\n  @Input() cpCloseClickOutside: boolean = true;\n\n  @Input() cpUseRootViewContainer: boolean = false;\n\n  @Input() cpPosition: string = 'auto';\n  @Input() cpPositionOffset: string = '0%';\n  @Input() cpPositionRelativeToArrow: boolean = false;\n\n  @Input() cpOKButton: boolean = false;\n  @Input() cpOKButtonText: string = 'OK';\n  @Input() cpOKButtonClass: string = 'cp-ok-button-class';\n\n  @Input() cpCancelButton: boolean = false;\n  @Input() cpCancelButtonText: string = 'Cancel';\n  @Input() cpCancelButtonClass: string = 'cp-cancel-button-class';\n\n  @Input() cpEyeDropper: boolean = false;\n\n  @Input() cpPresetLabel: string = 'Preset colors';\n  @Input() cpPresetColors: string[];\n  @Input() cpPresetColorsClass: string = 'cp-preset-colors-class';\n  @Input() cpMaxPresetColorsLength: number = 6;\n\n  @Input() cpPresetEmptyMessage: string = 'No colors added';\n  @Input() cpPresetEmptyMessageClass: string = 'preset-empty-message';\n\n  @Input() cpAddColorButton: boolean = false;\n  @Input() cpAddColorButtonText: string = 'Add color';\n  @Input() cpAddColorButtonClass: string = 'cp-add-color-button-class';\n\n  @Input() cpRemoveColorButtonClass: string = 'cp-remove-color-button-class';\n  @Input() cpArrowPosition: number = 0;\n\n  @Input() cpExtraTemplate: TemplateRef<any>;\n\n  @Output() cpInputChange = new EventEmitter<{input: string, value: number | string, color: string}>(true);\n\n  @Output() cpToggleChange = new EventEmitter<boolean>(true);\n\n  @Output() cpSliderChange = new EventEmitter<{slider: string, value: string | number, color: string}>(true);\n  @Output() cpSliderDragEnd = new EventEmitter<{slider: string, color: string}>(true);\n  @Output() cpSliderDragStart = new EventEmitter<{slider: string, color: string}>(true);\n\n  @Output() colorPickerOpen = new EventEmitter<string>(true);\n  @Output() colorPickerClose = new EventEmitter<string>(true);\n\n  @Output() colorPickerCancel = new EventEmitter<string>(true);\n  @Output() colorPickerSelect = new EventEmitter<string>(true);\n  @Output() colorPickerChange = new EventEmitter<string>(false);\n\n  @Output() cpCmykColorChange = new EventEmitter<string>(true);\n\n  @Output() cpPresetColorsChange = new EventEmitter<any>(true);\n\n  @HostListener('click') handleClick(): void {\n    this.inputFocus();\n  }\n\n  @HostListener('focus') handleFocus(): void {\n    this.inputFocus();\n  }\n\n  @HostListener('input', ['$event']) handleInput(event: any): void {\n    this.inputChange(event);\n  }\n\n  constructor(private injector: Injector, private cfr: ComponentFactoryResolver,\n    private appRef: ApplicationRef, private vcRef: ViewContainerRef, private elRef: ElementRef,\n    private _service: ColorPickerService) {}\n\n  ngOnDestroy(): void {\n    if (this.cmpRef != null) {\n      if (this.viewAttachedToAppRef) {\n        this.appRef.detachView(this.cmpRef.hostView);\n      }\n\n      this.cmpRef.destroy();\n\n      this.cmpRef = null;\n      this.dialog = null;\n    }\n  }\n\n  ngOnChanges(changes: any): void {\n    if (changes.cpToggle && !this.cpDisabled) {\n      if (changes.cpToggle.currentValue) {\n        this.openDialog();\n      } else if (!changes.cpToggle.currentValue) {\n        this.closeDialog();\n      }\n    }\n\n    if (changes.colorPicker) {\n      if (this.dialog && !this.ignoreChanges) {\n        if (this.cpDialogDisplay === 'inline') {\n          this.dialog.setInitialColor(changes.colorPicker.currentValue);\n        }\n\n        this.dialog.setColorFromString(changes.colorPicker.currentValue, false);\n\n        if (this.cpUseRootViewContainer && this.cpDialogDisplay !== 'inline') {\n          this.cmpRef.changeDetectorRef.detectChanges();\n        }\n      }\n\n      this.ignoreChanges = false;\n    }\n\n    if (changes.cpPresetLabel || changes.cpPresetColors) {\n      if (this.dialog) {\n        this.dialog.setPresetConfig(this.cpPresetLabel, this.cpPresetColors);\n      }\n    }\n  }\n\n  public openDialog(): void {\n    if (!this.dialogCreated) {\n      let vcRef = this.vcRef;\n\n      this.dialogCreated = true;\n      this.viewAttachedToAppRef = false;\n\n      if (this.cpUseRootViewContainer && this.cpDialogDisplay !== 'inline') {\n        const classOfRootComponent = this.appRef.componentTypes[0];\n        const appInstance = this.injector.get(classOfRootComponent, Injector.NULL);\n\n        if (appInstance !== Injector.NULL) {\n          vcRef = appInstance.vcRef || appInstance.viewContainerRef || this.vcRef;\n\n          if (NG_DEV_MODE && vcRef === this.vcRef) {\n            console.warn('You are using cpUseRootViewContainer, ' +\n              'but the root component is not exposing viewContainerRef!' +\n              'Please expose it by adding \\'public vcRef: ViewContainerRef\\' to the constructor.');\n          }\n        } else {\n          this.viewAttachedToAppRef = true;\n        }\n      }\n\n      const compFactory = this.cfr.resolveComponentFactory(ColorPickerComponent);\n\n      if (this.viewAttachedToAppRef) {\n        this.cmpRef = compFactory.create(this.injector);\n        this.appRef.attachView(this.cmpRef.hostView);\n        document.body.appendChild((this.cmpRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement);\n      } else {\n        const injector = Injector.create({\n          providers: [],\n          // We shouldn't use `vcRef.parentInjector` since it's been deprecated long time ago and might be removed\n          // in newer Angular versions: https://github.com/angular/angular/pull/25174.\n          parent: vcRef.injector,\n        });\n\n        this.cmpRef = vcRef.createComponent(compFactory, 0, injector, []);\n      }\n\n      this.cmpRef.instance.setupDialog(this, this.elRef, this.colorPicker,\n        this.cpWidth, this.cpHeight, this.cpDialogDisplay, this.cpFallbackColor, this.cpColorMode,\n        this.cpCmykEnabled, this.cpAlphaChannel, this.cpOutputFormat, this.cpDisableInput,\n        this.cpIgnoredElements, this.cpSaveClickOutside, this.cpCloseClickOutside,\n        this.cpUseRootViewContainer, this.cpPosition, this.cpPositionOffset,\n        this.cpPositionRelativeToArrow, this.cpPresetLabel, this.cpPresetColors,\n        this.cpPresetColorsClass, this.cpMaxPresetColorsLength, this.cpPresetEmptyMessage,\n        this.cpPresetEmptyMessageClass, this.cpOKButton, this.cpOKButtonClass,\n        this.cpOKButtonText, this.cpCancelButton, this.cpCancelButtonClass,\n        this.cpCancelButtonText, this.cpAddColorButton, this.cpAddColorButtonClass,\n        this.cpAddColorButtonText, this.cpRemoveColorButtonClass, this.cpEyeDropper, this.elRef,\n        this.cpExtraTemplate);\n\n      this.dialog = this.cmpRef.instance;\n\n      if (this.vcRef !== vcRef) {\n        this.cmpRef.changeDetectorRef.detectChanges();\n      }\n    } else if (this.dialog) {\n      this.dialog.openDialog(this.colorPicker);\n    }\n  }\n\n  public closeDialog(): void {\n    if (this.dialog && this.cpDialogDisplay === 'popup') {\n      this.dialog.closeDialog();\n    }\n  }\n\n  public cmykChanged(value: string): void {\n    this.cpCmykColorChange.emit(value);\n  }\n\n  public stateChanged(state: boolean): void {\n    this.cpToggleChange.emit(state);\n\n    if (state) {\n      this.colorPickerOpen.emit(this.colorPicker);\n    } else {\n      this.colorPickerClose.emit(this.colorPicker);\n    }\n  }\n\n  public colorChanged(value: string, ignore: boolean = true): void {\n    this.ignoreChanges = ignore;\n\n    this.colorPickerChange.emit(value);\n  }\n\n  public colorSelected(value: string): void {\n    this.colorPickerSelect.emit(value);\n  }\n\n  public colorCanceled(): void {\n    this.colorPickerCancel.emit();\n  }\n\n  public inputFocus(): void {\n    const element = this.elRef.nativeElement;\n\n    const ignored = this.cpIgnoredElements.filter((item: any) => item === element);\n\n    if (!this.cpDisabled && !ignored.length) {\n      if (typeof document !== 'undefined' && element === document.activeElement) {\n        this.openDialog();\n      } else if (!this.dialog || !this.dialog.show) {\n        this.openDialog();\n      } else {\n        this.closeDialog();\n      }\n    }\n  }\n\n  public inputChange(event: any): void {\n    if (this.dialog) {\n      this.dialog.setColorFromString(event.target.value, true);\n    } else {\n      this.colorPicker = event.target.value;\n\n      this.colorPickerChange.emit(this.colorPicker);\n    }\n  }\n\n  public inputChanged(event: any): void {\n    this.cpInputChange.emit(event);\n  }\n\n  public sliderChanged(event: any): void {\n    this.cpSliderChange.emit(event);\n  }\n\n  public sliderDragEnd(event: { slider: string, color: string }): void {\n    this.cpSliderDragEnd.emit(event);\n  }\n\n  public sliderDragStart(event: { slider: string, color: string }): void {\n    this.cpSliderDragStart.emit(event);\n  }\n\n  public presetColorsChanged(value: any[]): void {\n    this.cpPresetColorsChange.emit(value);\n  }\n}\n"]}