UNPKG

@doku-dev/doku-fragment

Version:

A new Angular UI library that moving away from Bootstrap and built from scratch.

137 lines 21.1 kB
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":"AAAA,OAAO,EAAE,YAAY,EAAW,MAAM,iBAAiB,CAAC;AACxD,OAAO,EACL,uBAAuB,EAEvB,SAAS,EACT,YAAY,EACZ,IAAI,EACJ,WAAW,EACX,KAAK,EAIL,QAAQ,EACR,MAAM,EACN,IAAI,EAEJ,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,WAAW,EAAa,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACnG,OAAO,EAAE,eAAe,EAAE,OAAO,EAAE,KAAK,EAAE,oBAAoB,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAC9F,OAAO,EACL,wBAAwB,EAIxB,mBAAmB,GAEpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;;;;;;AAYrC,MAAM,OAAO,eAAe;IAe1B;;;OAGG;IACH,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC;IAC3B,CAAC;IACD,IAAI,KAAK,CAAC,QAAmC;QAC3C,IAAI,CAAC,MAAM,GAAG,QAAQ,IAAI,EAAE,CAAC;QAC7B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC;IAcD,YACU,GAAsB,EACF,SAAoB,EAClB,SAAyB;QAF/C,QAAG,GAAH,GAAG,CAAmB;QACF,cAAS,GAAT,SAAS,CAAW;QAClB,cAAS,GAAT,SAAS,CAAgB;QAxCzD;;;WAGG;QACM,aAAQ,GAAG,KAAK,CAAC;QAE1B;;;WAGG;QACM,aAAQ,GAAG,KAAK,CAAC;QAclB,WAAM,GAAG,EAAE,CAAC;QAEpB;;WAEG;QACO,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QAGhC,YAAO,GAAuB,CAAC,gBAAgB,CAAC,CAAC;QAE5D,WAAM,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACzC,aAAQ,GAAG,IAAI,OAAO,EAAE,CAAC;QAYjC,iBAAY,GAAsC,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC;QAL5E,IAAI,SAAS,EAAE;YACb,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,IAAI,CAAC;SACrC;IACH,CAAC;IAMD,iBAAiB,CAAC,EAA4B;QAC5C,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IACD,kBAAkB,CAAC,EAA4B;QAC7C,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IACD,kBAAkB,CAAE,EAAoE;QACtF,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAID,UAAU,CAAC,KAAc;QACvB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IACD,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IACD,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IACD,gBAAgB,CAAE,UAAmB;QACnC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,MAAM;aACR,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,oBAAoB,EAAE,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC/D,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC7B,IAAI,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,SAAS,EAAE,aAAa;YAC3B,EAAE,IAAI,CAAC,oBAAoB,EAAE,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aACjE,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACpB,IAAI,MAAM,KAAK,OAAO,EAAE;gBACtB,IAAI,CAAC,UAAU,EAAE,CAAC,OAAO,CAAC,CAAC;aAC5B;iBAAM,IAAI,MAAM,KAAK,SAAS,EAAE;gBAC/B,IAAI,CAAC,UAAU,EAAE,CAAC,SAAS,CAAC,CAAC;aAC9B;iBAAM;gBACL,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;aACrB;YACD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,UAAU,CAAC,EAAE,aAAa,KAAK,OAAO,CAAC,UAAU,CAAC,EAAE,YAAY,EAAE;YAC5E,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACnC;QAED,IAAI,OAAO,CAAC,UAAU,CAAC,EAAE,aAAa,KAAK,OAAO,CAAC,UAAU,CAAC,EAAE,YAAY,EAAE;YAC5E,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACpC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;IAC9B,CAAC;IAES,aAAa,CAAC,KAAY;QAClC,IAAI,CAAC,KAAK,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QACtD,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;IACrB,CAAC;;4GAxHU,eAAe;gGAAf,eAAe,oOAFf,CAAC,EAAE,OAAO,EAAE,wBAAwB,EAAE,WAAW,EAAE,eAAe,EAAE,CAAC,8ECtClF,uvBAyBA,2CDSY,YAAY,8BAAE,mBAAmB,0WAAE,SAAS,8IAAE,mBAAmB,yjBAAE,WAAW;2FAM7E,eAAe;kBAV3B,SAAS;+BACE,mBAAmB,YACnB,iBAAiB,cACf,IAAI,WACP,CAAC,YAAY,EAAE,mBAAmB,EAAE,SAAS,EAAE,mBAAmB,EAAE,WAAW,CAAC,iBAE1E,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,aACpC,CAAC,EAAE,OAAO,EAAE,wBAAwB,EAAE,WAAW,iBAAiB,EAAE,CAAC;;0BA4C7E,QAAQ;;0BAAI,IAAI;;0BAChB,QAAQ;;0BAAI,IAAI;4CApCV,QAAQ;sBAAhB,KAAK;gBAMG,QAAQ;sBAAhB,KAAK;gBAOF,KAAK;sBADR,KAAK;gBAaI,WAAW;sBAApB,MAAM;gBAGY,OAAO;sBADzB,WAAW;uBAAC,OAAO","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"]}