UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

325 lines 33.3 kB
/** * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ import { NgTemplateOutlet } from '@angular/common'; import { booleanAttribute, ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Output } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { isNonEmptyString, isTemplateRef } from 'ng-zorro-antd/core/util'; import { NzPopoverDirective } from 'ng-zorro-antd/popover'; import { NzColorBlockComponent } from './color-block.component'; import { NzColorFormatComponent } from './color-format.component'; import { NgAntdColorPickerModule } from './src/ng-antd-color-picker.module'; import { defaultColor, generateColor } from './src/util/util'; import * as i0 from "@angular/core"; import * as i1 from "@angular/forms"; import * as i2 from "./src/ng-antd-color-picker.component"; export class NzColorPickerComponent { constructor(formBuilder, cdr) { this.formBuilder = formBuilder; this.cdr = cdr; this.nzFormat = null; this.nzValue = ''; this.nzSize = 'default'; this.nzDefaultValue = ''; this.nzTrigger = 'click'; this.nzTitle = ''; this.nzFlipFlop = null; this.nzShowText = false; this.nzOpen = false; this.nzAllowClear = false; this.nzDisabled = false; this.nzDisabledAlpha = false; this.nzOnChange = new EventEmitter(); this.nzOnFormatChange = new EventEmitter(); this.nzOnClear = new EventEmitter(); this.nzOnOpenChange = new EventEmitter(); this.isTemplateRef = isTemplateRef; this.isNonEmptyString = isNonEmptyString; this.destroy$ = new Subject(); this.isNzDisableFirstChange = true; this.blockColor = ''; this.clearColor = false; this.showText = defaultColor.toHexString(); this.formControl = this.formBuilder.control(''); this.onChange = () => { }; } writeValue(value) { this.nzValue = value; this.getBlockColor(); this.formControl.patchValue(value); } registerOnChange(fn) { this.onChange = fn; } registerOnTouched() { } setDisabledState(isDisabled) { this.nzDisabled = (this.isNzDisableFirstChange && this.nzDisabled) || isDisabled; this.isNzDisableFirstChange = false; this.cdr.markForCheck(); } ngOnInit() { this.getBlockColor(); this.formControl.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(value => { if (!!value) { let color = value; if (this.nzFormat === 'hex') { color = generateColor(value).getAlpha() < 1 ? generateColor(value).toHex8String() : generateColor(value).toHexString(); } else if (this.nzFormat === 'hsb') { color = generateColor(value).toHsbString(); } else if (this.nzFormat === 'rgb') { color = generateColor(value).toRgbString(); } this.showText = color; this.onChange(color); this.cdr.markForCheck(); } }); } ngOnChanges(changes) { const { nzValue, nzDefaultValue } = changes; if (nzValue || nzDefaultValue) { this.getBlockColor(); } } clearColorHandle() { this.clearColor = true; this.nzOnClear.emit(true); this.cdr.markForCheck(); } getBlockColor() { if (!!this.nzValue) { this.blockColor = generateColor(this.nzValue).toRgbString(); } else if (!!this.nzDefaultValue) { this.blockColor = generateColor(this.nzDefaultValue).toRgbString(); } else { this.blockColor = defaultColor.toHexString(); } } colorChange(value) { this.blockColor = value.color.getAlpha() < 1 ? value.color.toHex8String() : value.color.toHexString(); this.clearColor = false; this.cdr.markForCheck(); } formatChange(value) { this.nzValue = value.color; this.clearColor = false; this.getBlockColor(); this.nzOnChange.emit({ color: generateColor(value.color), format: value.format }); this.formControl.patchValue(value.color); this.cdr.markForCheck(); } ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } get isNzTitleNonEmptyString() { return isNonEmptyString(this.nzTitle); } get isNzTitleTemplateRef() { return isTemplateRef(this.nzTitle); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzColorPickerComponent, deps: [{ token: i1.FormBuilder }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.2", type: NzColorPickerComponent, isStandalone: true, selector: "nz-color-picker", inputs: { nzFormat: "nzFormat", nzValue: "nzValue", nzSize: "nzSize", nzDefaultValue: "nzDefaultValue", nzTrigger: "nzTrigger", nzTitle: "nzTitle", nzFlipFlop: "nzFlipFlop", nzShowText: ["nzShowText", "nzShowText", booleanAttribute], nzOpen: ["nzOpen", "nzOpen", booleanAttribute], nzAllowClear: ["nzAllowClear", "nzAllowClear", booleanAttribute], nzDisabled: ["nzDisabled", "nzDisabled", booleanAttribute], nzDisabledAlpha: ["nzDisabledAlpha", "nzDisabledAlpha", booleanAttribute] }, outputs: { nzOnChange: "nzOnChange", nzOnFormatChange: "nzOnFormatChange", nzOnClear: "nzOnClear", nzOnOpenChange: "nzOnOpenChange" }, host: { properties: { "class.ant-color-picker-disabled": "nzDisabled" }, classAttribute: "ant-color-picker-inline" }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NzColorPickerComponent), multi: true } ], exportAs: ["NzColorPicker"], usesOnChanges: true, ngImport: i0, template: ` <div [class.ant-color-picker-trigger]="!nzFlipFlop" [class.ant-color-picker-sm]="nzSize === 'small'" [class.ant-color-picker-lg]="nzSize === 'large'" nz-popover [nzPopoverContent]="colorPicker" [nzPopoverTrigger]="!nzDisabled ? nzTrigger : null" [nzPopoverVisible]="nzOpen" (nzPopoverVisibleChange)="nzOnOpenChange.emit($event)" > @if (!nzFlipFlop) { <nz-color-block [nzColor]="blockColor" [nzSize]="nzSize" /> } @else { <ng-template [ngTemplateOutlet]="nzFlipFlop" /> } @if (nzShowText && !!showText && !nzFlipFlop) { <div class="ant-color-picker-trigger-text"> {{ showText }} </div> } </div> <ng-template #colorPicker> <ng-antd-color-picker [value]="nzValue" [defaultValue]="nzDefaultValue" [disabled]="nzDisabled" [panelRenderHeader]="nzPanelRenderHeader" [panelRenderFooter]="nzPanelRenderFooter" [disabledAlpha]="nzDisabledAlpha" (nzOnChange)="colorChange($event)" /> </ng-template> <ng-template #nzPanelRenderHeader> @if (nzTitle || nzAllowClear) { <div class="ant-color-picker-title"> <div class="ant-color-picker-title-content"> @if (isNzTitleTemplateRef) { <ng-container *ngTemplateOutlet="$any(nzTitle)" /> } @if (isNzTitleNonEmptyString) { <span [innerHTML]="nzTitle"></span> } </div> @if (nzAllowClear) { <div class="ant-color-picker-clear" (click)="clearColorHandle()"></div> } </div> } </ng-template> <ng-template #nzPanelRenderFooter> <nz-color-format [colorValue]="blockColor" [clearColor]="clearColor" [format]="nzFormat" [nzDisabledAlpha]="nzDisabledAlpha" (formatChange)="formatChange($event)" (nzOnFormatChange)="nzOnFormatChange.emit($event)" /> </ng-template> `, isInline: true, dependencies: [{ kind: "ngmodule", type: NgAntdColorPickerModule }, { kind: "component", type: i2.NgAntdColorPickerComponent, selector: "ng-antd-color-picker", inputs: ["value", "defaultValue", "panelRenderHeader", "panelRenderFooter", "disabledAlpha", "disabled"], outputs: ["nzOnChange", "nzOnChangeComplete"] }, { kind: "directive", type: NzPopoverDirective, selector: "[nz-popover]", inputs: ["nzPopoverArrowPointAtCenter", "nzPopoverTitle", "nzPopoverContent", "nz-popover", "nzPopoverTrigger", "nzPopoverPlacement", "nzPopoverOrigin", "nzPopoverVisible", "nzPopoverMouseEnterDelay", "nzPopoverMouseLeaveDelay", "nzPopoverOverlayClassName", "nzPopoverOverlayStyle", "nzPopoverBackdrop"], outputs: ["nzPopoverVisibleChange"], exportAs: ["nzPopover"] }, { kind: "component", type: NzColorBlockComponent, selector: "nz-color-block", inputs: ["nzColor", "nzSize"], outputs: ["nzOnClick"], exportAs: ["NzColorBlock"] }, { kind: "component", type: NzColorFormatComponent, selector: "nz-color-format", inputs: ["format", "colorValue", "clearColor", "nzDisabledAlpha"], outputs: ["formatChange", "nzOnFormatChange"], exportAs: ["NzColorFormat"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzColorPickerComponent, decorators: [{ type: Component, args: [{ selector: 'nz-color-picker', exportAs: 'NzColorPicker', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ NgAntdColorPickerModule, NzPopoverDirective, NzColorBlockComponent, NzColorFormatComponent, NgTemplateOutlet ], template: ` <div [class.ant-color-picker-trigger]="!nzFlipFlop" [class.ant-color-picker-sm]="nzSize === 'small'" [class.ant-color-picker-lg]="nzSize === 'large'" nz-popover [nzPopoverContent]="colorPicker" [nzPopoverTrigger]="!nzDisabled ? nzTrigger : null" [nzPopoverVisible]="nzOpen" (nzPopoverVisibleChange)="nzOnOpenChange.emit($event)" > @if (!nzFlipFlop) { <nz-color-block [nzColor]="blockColor" [nzSize]="nzSize" /> } @else { <ng-template [ngTemplateOutlet]="nzFlipFlop" /> } @if (nzShowText && !!showText && !nzFlipFlop) { <div class="ant-color-picker-trigger-text"> {{ showText }} </div> } </div> <ng-template #colorPicker> <ng-antd-color-picker [value]="nzValue" [defaultValue]="nzDefaultValue" [disabled]="nzDisabled" [panelRenderHeader]="nzPanelRenderHeader" [panelRenderFooter]="nzPanelRenderFooter" [disabledAlpha]="nzDisabledAlpha" (nzOnChange)="colorChange($event)" /> </ng-template> <ng-template #nzPanelRenderHeader> @if (nzTitle || nzAllowClear) { <div class="ant-color-picker-title"> <div class="ant-color-picker-title-content"> @if (isNzTitleTemplateRef) { <ng-container *ngTemplateOutlet="$any(nzTitle)" /> } @if (isNzTitleNonEmptyString) { <span [innerHTML]="nzTitle"></span> } </div> @if (nzAllowClear) { <div class="ant-color-picker-clear" (click)="clearColorHandle()"></div> } </div> } </ng-template> <ng-template #nzPanelRenderFooter> <nz-color-format [colorValue]="blockColor" [clearColor]="clearColor" [format]="nzFormat" [nzDisabledAlpha]="nzDisabledAlpha" (formatChange)="formatChange($event)" (nzOnFormatChange)="nzOnFormatChange.emit($event)" /> </ng-template> `, host: { class: 'ant-color-picker-inline', '[class.ant-color-picker-disabled]': `nzDisabled` }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => NzColorPickerComponent), multi: true } ] }] }], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i0.ChangeDetectorRef }], propDecorators: { nzFormat: [{ type: Input }], nzValue: [{ type: Input }], nzSize: [{ type: Input }], nzDefaultValue: [{ type: Input }], nzTrigger: [{ type: Input }], nzTitle: [{ type: Input }], nzFlipFlop: [{ type: Input }], nzShowText: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzOpen: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzAllowClear: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzDisabled: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzDisabledAlpha: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzOnChange: [{ type: Output }], nzOnFormatChange: [{ type: Output }], nzOnClear: [{ type: Output }], nzOnOpenChange: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.component.js","sourceRoot":"","sources":["../../../components/color-picker/color-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { NgTemplateOutlet } from '@angular/common';\nimport {\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef\n} from '@angular/core';\nimport { ControlValueAccessor, FormBuilder, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { NzSafeAny, NzSizeLDSType } from 'ng-zorro-antd/core/types';\nimport { isNonEmptyString, isTemplateRef } from 'ng-zorro-antd/core/util';\nimport { NzPopoverDirective } from 'ng-zorro-antd/popover';\n\nimport { NzColorBlockComponent } from './color-block.component';\nimport { NzColorFormatComponent } from './color-format.component';\nimport { NgAntdColorPickerModule } from './src/ng-antd-color-picker.module';\nimport { defaultColor, generateColor } from './src/util/util';\nimport { NzColor, NzColorPickerFormatType, NzColorPickerTriggerType } from './typings';\n\n@Component({\n  selector: 'nz-color-picker',\n  exportAs: 'NzColorPicker',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgAntdColorPickerModule,\n    NzPopoverDirective,\n    NzColorBlockComponent,\n    NzColorFormatComponent,\n    NgTemplateOutlet\n  ],\n  template: `\n    <div\n      [class.ant-color-picker-trigger]=\"!nzFlipFlop\"\n      [class.ant-color-picker-sm]=\"nzSize === 'small'\"\n      [class.ant-color-picker-lg]=\"nzSize === 'large'\"\n      nz-popover\n      [nzPopoverContent]=\"colorPicker\"\n      [nzPopoverTrigger]=\"!nzDisabled ? nzTrigger : null\"\n      [nzPopoverVisible]=\"nzOpen\"\n      (nzPopoverVisibleChange)=\"nzOnOpenChange.emit($event)\"\n    >\n      @if (!nzFlipFlop) {\n        <nz-color-block [nzColor]=\"blockColor\" [nzSize]=\"nzSize\" />\n      } @else {\n        <ng-template [ngTemplateOutlet]=\"nzFlipFlop\" />\n      }\n      @if (nzShowText && !!showText && !nzFlipFlop) {\n        <div class=\"ant-color-picker-trigger-text\">\n          {{ showText }}\n        </div>\n      }\n    </div>\n    <ng-template #colorPicker>\n      <ng-antd-color-picker\n        [value]=\"nzValue\"\n        [defaultValue]=\"nzDefaultValue\"\n        [disabled]=\"nzDisabled\"\n        [panelRenderHeader]=\"nzPanelRenderHeader\"\n        [panelRenderFooter]=\"nzPanelRenderFooter\"\n        [disabledAlpha]=\"nzDisabledAlpha\"\n        (nzOnChange)=\"colorChange($event)\"\n      />\n    </ng-template>\n    <ng-template #nzPanelRenderHeader>\n      @if (nzTitle || nzAllowClear) {\n        <div class=\"ant-color-picker-title\">\n          <div class=\"ant-color-picker-title-content\">\n            @if (isNzTitleTemplateRef) {\n              <ng-container *ngTemplateOutlet=\"$any(nzTitle)\" />\n            }\n            @if (isNzTitleNonEmptyString) {\n              <span [innerHTML]=\"nzTitle\"></span>\n            }\n          </div>\n          @if (nzAllowClear) {\n            <div class=\"ant-color-picker-clear\" (click)=\"clearColorHandle()\"></div>\n          }\n        </div>\n      }\n    </ng-template>\n    <ng-template #nzPanelRenderFooter>\n      <nz-color-format\n        [colorValue]=\"blockColor\"\n        [clearColor]=\"clearColor\"\n        [format]=\"nzFormat\"\n        [nzDisabledAlpha]=\"nzDisabledAlpha\"\n        (formatChange)=\"formatChange($event)\"\n        (nzOnFormatChange)=\"nzOnFormatChange.emit($event)\"\n      />\n    </ng-template>\n  `,\n  host: {\n    class: 'ant-color-picker-inline',\n    '[class.ant-color-picker-disabled]': `nzDisabled`\n  },\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => NzColorPickerComponent),\n      multi: true\n    }\n  ]\n})\nexport class NzColorPickerComponent implements OnInit, OnChanges, ControlValueAccessor, OnDestroy {\n  @Input() nzFormat: NzColorPickerFormatType | null = null;\n  @Input() nzValue: string | NzColor = '';\n  @Input() nzSize: NzSizeLDSType = 'default';\n  @Input() nzDefaultValue: string | NzColor = '';\n  @Input() nzTrigger: NzColorPickerTriggerType = 'click';\n  @Input() nzTitle: TemplateRef<void> | string = '';\n  @Input() nzFlipFlop: TemplateRef<void> | null = null;\n  @Input({ transform: booleanAttribute }) nzShowText: boolean = false;\n  @Input({ transform: booleanAttribute }) nzOpen: boolean = false;\n  @Input({ transform: booleanAttribute }) nzAllowClear: boolean = false;\n  @Input({ transform: booleanAttribute }) nzDisabled: boolean = false;\n  @Input({ transform: booleanAttribute }) nzDisabledAlpha: boolean = false;\n  @Output() readonly nzOnChange = new EventEmitter<{ color: NzColor; format: string }>();\n  @Output() readonly nzOnFormatChange = new EventEmitter<NzColorPickerFormatType>();\n  @Output() readonly nzOnClear = new EventEmitter<boolean>();\n  @Output() readonly nzOnOpenChange = new EventEmitter<boolean>();\n\n  protected readonly isTemplateRef = isTemplateRef;\n  protected readonly isNonEmptyString = isNonEmptyString;\n  private destroy$ = new Subject<void>();\n  private isNzDisableFirstChange: boolean = true;\n  blockColor: string = '';\n  clearColor: boolean = false;\n  showText: string = defaultColor.toHexString();\n\n  constructor(\n    private formBuilder: FormBuilder,\n    private cdr: ChangeDetectorRef\n  ) {}\n\n  formControl = this.formBuilder.control('');\n\n  onChange: (value: string) => void = () => {};\n\n  writeValue(value: string): void {\n    this.nzValue = value;\n    this.getBlockColor();\n    this.formControl.patchValue(value);\n  }\n\n  registerOnChange(fn: NzSafeAny): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(): void {}\n\n  setDisabledState(isDisabled: boolean): void {\n    this.nzDisabled = (this.isNzDisableFirstChange && this.nzDisabled) || isDisabled;\n    this.isNzDisableFirstChange = false;\n    this.cdr.markForCheck();\n  }\n\n  ngOnInit(): void {\n    this.getBlockColor();\n    this.formControl.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(value => {\n      if (!!value) {\n        let color = value;\n        if (this.nzFormat === 'hex') {\n          color =\n            generateColor(value).getAlpha() < 1\n              ? generateColor(value).toHex8String()\n              : generateColor(value).toHexString();\n        } else if (this.nzFormat === 'hsb') {\n          color = generateColor(value).toHsbString();\n        } else if (this.nzFormat === 'rgb') {\n          color = generateColor(value).toRgbString();\n        }\n        this.showText = color;\n        this.onChange(color);\n        this.cdr.markForCheck();\n      }\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { nzValue, nzDefaultValue } = changes;\n    if (nzValue || nzDefaultValue) {\n      this.getBlockColor();\n    }\n  }\n\n  clearColorHandle(): void {\n    this.clearColor = true;\n    this.nzOnClear.emit(true);\n    this.cdr.markForCheck();\n  }\n\n  getBlockColor(): void {\n    if (!!this.nzValue) {\n      this.blockColor = generateColor(this.nzValue).toRgbString();\n    } else if (!!this.nzDefaultValue) {\n      this.blockColor = generateColor(this.nzDefaultValue).toRgbString();\n    } else {\n      this.blockColor = defaultColor.toHexString();\n    }\n  }\n\n  colorChange(value: { color: NzColor }): void {\n    this.blockColor = value.color.getAlpha() < 1 ? value.color.toHex8String() : value.color.toHexString();\n    this.clearColor = false;\n    this.cdr.markForCheck();\n  }\n\n  formatChange(value: { color: string; format: NzColorPickerFormatType }): void {\n    this.nzValue = value.color;\n    this.clearColor = false;\n    this.getBlockColor();\n    this.nzOnChange.emit({ color: generateColor(value.color), format: value.format });\n    this.formControl.patchValue(value.color);\n    this.cdr.markForCheck();\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  get isNzTitleNonEmptyString(): boolean {\n    return isNonEmptyString(this.nzTitle);\n  }\n\n  get isNzTitleTemplateRef(): boolean {\n    return isTemplateRef(this.nzTitle);\n  }\n}\n"]}