@doku-dev/doku-fragment
Version:
A new Angular UI library that moving away from Bootstrap and built from scratch.
137 lines • 21.1 kB
JavaScript
import { CommonModule } from '@angular/common';
import { ChangeDetectionStrategy, Component, EventEmitter, Host, HostBinding, Input, Optional, Output, Self, ViewEncapsulation, } from '@angular/core';
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
import { BehaviorSubject, Subject, delay, distinctUntilChanged, skip, takeUntil } from 'rxjs';
import { DOKU_FORM_FIELD_ACCESSOR, DokuFormFieldModule, } from '../form-field';
import { DokuInput } from '../input';
import * as i0 from "@angular/core";
import * as i1 from "@angular/forms";
import * as i2 from "../form-field";
import * as i3 from "../form-field/form-field.component";
import * as i4 from "../form-field/directives/field-prefix.directive";
export class DokuColorPicker {
/**
* Value of the color picker in hexadecimal format.
* @default ''
*/
get value() {
return this._value || '';
}
set value(hexColor) {
this._value = hexColor || '';
this.value$.next(this._value);
}
constructor(cdr, ngControl, formField) {
this.cdr = cdr;
this.ngControl = ngControl;
this.formField = formField;
/**
* Whether to disable the color picker.
* @default false
*/
this.disabled = false;
/**
* Whether color picker is readonly.
* @default false
*/
this.readonly = false;
this._value = '';
/**
* An event emitted when value changes.
*/
this.valueChange = new EventEmitter();
this.classes = ['d-color-picker'];
this.value$ = new BehaviorSubject(this.value);
this.destroy$ = new Subject();
this.fieldOptions = { withoutInputStyle: true };
if (ngControl) {
this.ngControl.valueAccessor = this;
}
}
registerOnDisable(fn) {
this.onDisable = fn;
}
registerOnReadonly(fn) {
this.onReadonly = fn;
}
registerOnValidate(fn) {
this.onValidate = fn;
}
writeValue(value) {
this.value = value;
}
registerOnChange(fn) {
this.onChange = fn;
}
registerOnTouched(fn) {
this.onTouched = fn;
}
setDisabledState(isDisabled) {
this.disabled = isDisabled;
}
ngOnInit() {
this.value$
.pipe(skip(1), distinctUntilChanged(), takeUntil(this.destroy$))
.subscribe((value) => {
this.valueChange.emit(value);
this.onChange?.(value);
this.cdr.detectChanges();
});
this.ngControl?.statusChanges
?.pipe(distinctUntilChanged(), delay(0), takeUntil(this.destroy$))
.subscribe((status) => {
if (status === 'VALID') {
this.onValidate?.('valid');
}
else if (status === 'INVALID') {
this.onValidate?.('invalid');
}
else {
this.onValidate?.();
}
this.cdr.detectChanges();
});
}
ngOnChanges(changes) {
if (changes['disabled']?.previousValue !== changes['disabled']?.currentValue) {
this.onDisable?.(!!this.disabled);
}
if (changes['readonly']?.previousValue !== changes['readonly']?.currentValue) {
this.onReadonly?.(!!this.readonly);
}
}
ngOnDestroy() {
this.destroy$.next(true);
this.destroy$.unsubscribe();
}
onColorChange(event) {
this.value = event.target.value;
this.onTouched?.();
}
}
DokuColorPicker.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DokuColorPicker, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NgControl, optional: true, self: true }, { token: i2.DokuFormField, host: true, optional: true }], target: i0.ɵɵFactoryTarget.Component });
DokuColorPicker.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: DokuColorPicker, isStandalone: true, selector: "doku-color-picker", inputs: { disabled: "disabled", readonly: "readonly", value: "value" }, outputs: { valueChange: "valueChange" }, host: { properties: { "class": "this.classes" } }, providers: [{ provide: DOKU_FORM_FIELD_ACCESSOR, useExisting: DokuColorPicker }], exportAs: ["dokuColorPicker"], usesOnChanges: true, ngImport: i0, template: "<doku-form-field\n [isErrorState]=\"formField?.['isError']\"\n [isSuccessState]=\"formField?.['isSuccess']\"\n [showSuccessBehavior]=\"!!formField?.['showSuccessBehavior']\"\n>\n <input\n type=\"text\"\n doku-input\n [(ngModel)]=\"value\"\n (input)=\"onColorChange($event)\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [maxlength]=\"7\"\n />\n <doku-form-field doku-field-prefix appearance=\"border-block-inside\" class=\"d-color-picker-prefix\">\n <input\n type=\"color\"\n class=\"d-color-picker-input-color\"\n [(ngModel)]=\"value\"\n (input)=\"onColorChange($event)\"\n [disabled]=\"disabled || readonly\"\n [readonly]=\"readonly\"\n />\n </doku-form-field>\n</doku-form-field>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: DokuFormFieldModule }, { kind: "component", type: i3.DokuFormField, selector: "doku-form-field", inputs: ["showSuccessBehavior", "isErrorState", "isSuccessState"], exportAs: ["dokuFormField"] }, { kind: "directive", type: i4.DokuFieldPrefix, selector: "[doku-field-prefix]", inputs: ["appearance", "useBackgroundColor"], exportAs: ["dokuFieldPrefix"] }, { kind: "directive", type: DokuInput, selector: "input[doku-input], textarea[doku-input]", inputs: ["disabled", "readonly"], exportAs: ["dokuInput"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DokuColorPicker, decorators: [{
type: Component,
args: [{ selector: 'doku-color-picker', exportAs: 'dokuColorPicker', standalone: true, imports: [CommonModule, DokuFormFieldModule, DokuInput, ReactiveFormsModule, FormsModule], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [{ provide: DOKU_FORM_FIELD_ACCESSOR, useExisting: DokuColorPicker }], template: "<doku-form-field\n [isErrorState]=\"formField?.['isError']\"\n [isSuccessState]=\"formField?.['isSuccess']\"\n [showSuccessBehavior]=\"!!formField?.['showSuccessBehavior']\"\n>\n <input\n type=\"text\"\n doku-input\n [(ngModel)]=\"value\"\n (input)=\"onColorChange($event)\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [maxlength]=\"7\"\n />\n <doku-form-field doku-field-prefix appearance=\"border-block-inside\" class=\"d-color-picker-prefix\">\n <input\n type=\"color\"\n class=\"d-color-picker-input-color\"\n [(ngModel)]=\"value\"\n (input)=\"onColorChange($event)\"\n [disabled]=\"disabled || readonly\"\n [readonly]=\"readonly\"\n />\n </doku-form-field>\n</doku-form-field>\n" }]
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.NgControl, decorators: [{
type: Optional
}, {
type: Self
}] }, { type: i2.DokuFormField, decorators: [{
type: Optional
}, {
type: Host
}] }]; }, propDecorators: { disabled: [{
type: Input
}], readonly: [{
type: Input
}], value: [{
type: Input
}], valueChange: [{
type: Output
}], classes: [{
type: HostBinding,
args: ['class']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/doku-fragment/src/lib/color-picker/color-picker.component.ts","../../../../../../projects/doku-fragment/src/lib/color-picker/color-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, NgClass } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Host,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  SimpleChanges,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NgControl, ReactiveFormsModule } from '@angular/forms';\nimport { BehaviorSubject, Subject, delay, distinctUntilChanged, skip, takeUntil } from 'rxjs';\nimport {\n  DOKU_FORM_FIELD_ACCESSOR,\n  DokuFormField,\n  DokuFormFieldAccessor,\n  DokuFormFieldAccessorValidateValue,\n  DokuFormFieldModule,\n  DokuFormFieldOptions,\n} from '../form-field';\nimport { DokuInput } from '../input';\n\n@Component({\n  selector: 'doku-color-picker',\n  exportAs: 'dokuColorPicker',\n  standalone: true,\n  imports: [CommonModule, DokuFormFieldModule, DokuInput, ReactiveFormsModule, FormsModule],\n  templateUrl: './color-picker.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [{ provide: DOKU_FORM_FIELD_ACCESSOR, useExisting: DokuColorPicker }],\n})\nexport class DokuColorPicker\n  implements DokuFormFieldAccessor, ControlValueAccessor, OnInit, OnDestroy, OnChanges\n{\n  /**\n   * Whether to disable the color picker.\n   * @default false\n   */\n  @Input() disabled = false;\n\n  /**\n   * Whether color picker is readonly.\n   * @default false\n   */\n  @Input() readonly = false;\n\n  /**\n   * Value of the color picker in hexadecimal format.\n   * @default ''\n   */\n  @Input()\n  get value(): string {\n    return this._value || '';\n  }\n  set value(hexColor: string | null | undefined) {\n    this._value = hexColor || '';\n    this.value$.next(this._value);\n  }\n  private _value = '';\n\n  /**\n   * An event emitted when value changes.\n   */\n  @Output() valueChange = new EventEmitter<string>();\n\n  @HostBinding('class')\n  protected readonly classes: NgClass['ngClass'] = ['d-color-picker'];\n\n  private value$ = new BehaviorSubject(this.value);\n  private destroy$ = new Subject();\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    @Optional() @Self() private ngControl: NgControl,\n    @Optional() @Host() protected formField?: DokuFormField\n  ) {\n    if (ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  fieldOptions?: DokuFormFieldOptions | undefined = { withoutInputStyle: true };\n  onDisable?: ((value: boolean) => void) | undefined;\n  onReadonly?: ((value: boolean) => void) | undefined;\n  onValidate?: ((value?: DokuFormFieldAccessorValidateValue | undefined) => void) | undefined;\n  registerOnDisable(fn: (value: boolean) => void): void {\n    this.onDisable = fn;\n  }\n  registerOnReadonly(fn: (value: boolean) => void): void {\n    this.onReadonly = fn;\n  }\n  registerOnValidate?(fn: (value?: DokuFormFieldAccessorValidateValue | undefined) => void): void {\n    this.onValidate = fn;\n  }\n\n  onChange?: (value: any) => void;\n  onTouched?: () => void;\n  writeValue(value?: string): void {\n    this.value = value;\n  }\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  ngOnInit(): void {\n    this.value$\n      .pipe(skip(1), distinctUntilChanged(), takeUntil(this.destroy$))\n      .subscribe((value) => {\n        this.valueChange.emit(value);\n        this.onChange?.(value);\n        this.cdr.detectChanges();\n      });\n\n    this.ngControl?.statusChanges\n      ?.pipe(distinctUntilChanged(), delay(0), takeUntil(this.destroy$))\n      .subscribe((status) => {\n        if (status === 'VALID') {\n          this.onValidate?.('valid');\n        } else if (status === 'INVALID') {\n          this.onValidate?.('invalid');\n        } else {\n          this.onValidate?.();\n        }\n        this.cdr.detectChanges();\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['disabled']?.previousValue !== changes['disabled']?.currentValue) {\n      this.onDisable?.(!!this.disabled);\n    }\n\n    if (changes['readonly']?.previousValue !== changes['readonly']?.currentValue) {\n      this.onReadonly?.(!!this.readonly);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next(true);\n    this.destroy$.unsubscribe();\n  }\n\n  protected onColorChange(event: Event) {\n    this.value = (event.target as HTMLInputElement).value;\n    this.onTouched?.();\n  }\n}\n","<doku-form-field\n  [isErrorState]=\"formField?.['isError']\"\n  [isSuccessState]=\"formField?.['isSuccess']\"\n  [showSuccessBehavior]=\"!!formField?.['showSuccessBehavior']\"\n>\n  <input\n    type=\"text\"\n    doku-input\n    [(ngModel)]=\"value\"\n    (input)=\"onColorChange($event)\"\n    [disabled]=\"disabled\"\n    [readonly]=\"readonly\"\n    [maxlength]=\"7\"\n  />\n  <doku-form-field doku-field-prefix appearance=\"border-block-inside\" class=\"d-color-picker-prefix\">\n    <input\n      type=\"color\"\n      class=\"d-color-picker-input-color\"\n      [(ngModel)]=\"value\"\n      (input)=\"onColorChange($event)\"\n      [disabled]=\"disabled || readonly\"\n      [readonly]=\"readonly\"\n    />\n  </doku-form-field>\n</doku-form-field>\n"]}