UNPKG

ng-zorro-antd

Version:

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

318 lines (314 loc) 36.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 { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, booleanAttribute } from '@angular/core'; import { ReactiveFormsModule } from '@angular/forms'; import { Subject } from 'rxjs'; import { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators'; import { NzInputDirective, NzInputGroupComponent } from 'ng-zorro-antd/input'; import { NzInputNumberComponent } from 'ng-zorro-antd/input-number'; import { NzSelectModule } from 'ng-zorro-antd/select'; import { generateColor } from './src/util/util'; import * as i0 from "@angular/core"; import * as i1 from "@angular/forms"; import * as i2 from "ng-zorro-antd/select"; export class NzColorFormatComponent { validatorFn() { return (control) => { const REGEXP = /^[0-9a-fA-F]{6}$/; if (!control.value) { return { error: true }; } else if (!REGEXP.test(control.value)) { return { error: true }; } return null; }; } constructor(formBuilder) { this.formBuilder = formBuilder; this.format = null; this.colorValue = ''; this.clearColor = false; this.nzDisabledAlpha = false; this.formatChange = new EventEmitter(); this.nzOnFormatChange = new EventEmitter(); this.destroy$ = new Subject(); this.formatterPercent = (value) => `${value} %`; this.parserPercent = (value) => value.replace(' %', ''); this.validateForm = this.formBuilder.nonNullable.group({ isFormat: this.formBuilder.control('hex'), hex: this.formBuilder.control('1677FF', this.validatorFn()), hsbH: 215, hsbS: 91, hsbB: 100, rgbR: 22, rgbG: 119, rgbB: 255, roundA: 100 }); } ngOnInit() { this.validateForm.valueChanges .pipe(filter(() => this.validateForm.valid), debounceTime(200), distinctUntilChanged((prev, current) => Object.keys(prev).every(key => prev[key] === current[key])), takeUntil(this.destroy$)) .subscribe(value => { let color = ''; switch (value.isFormat) { case 'hsb': color = generateColor({ h: Number(value.hsbH), s: Number(value.hsbS) / 100, b: Number(value.hsbB) / 100, a: Number(value.roundA) / 100 }).toHsbString(); break; case 'rgb': color = generateColor({ r: Number(value.rgbR), g: Number(value.rgbG), b: Number(value.rgbB), a: Number(value.roundA) / 100 }).toRgbString(); break; default: const hex = generateColor(value.hex); const hexColor = generateColor({ r: hex.r, g: hex.g, b: hex.b, a: Number(value.roundA) / 100 }); color = hexColor.getAlpha() < 1 ? hexColor.toHex8String() : hexColor.toHexString(); break; } this.formatChange.emit({ color, format: value.isFormat || this.format || 'hex' }); }); this.validateForm .get('isFormat') ?.valueChanges.pipe(takeUntil(this.destroy$)) .subscribe(value => { this.nzOnFormatChange.emit(value); }); } ngOnChanges(changes) { const { colorValue, format, clearColor } = changes; if (colorValue) { const colorValue = { hex: generateColor(this.colorValue).toHex(), hsbH: Math.round(generateColor(this.colorValue).toHsb().h), hsbS: Math.round(generateColor(this.colorValue).toHsb().s * 100), hsbB: Math.round(generateColor(this.colorValue).toHsb().b * 100), rgbR: Math.round(generateColor(this.colorValue).r), rgbG: Math.round(generateColor(this.colorValue).g), rgbB: Math.round(generateColor(this.colorValue).b), roundA: Math.round(generateColor(this.colorValue).roundA * 100) }; this.validateForm.patchValue(colorValue); } if (format && this.format) { this.validateForm.get('isFormat')?.patchValue(this.format); } if (clearColor && this.clearColor) { this.validateForm.get('roundA')?.patchValue(0); } } ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzColorFormatComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.2", type: NzColorFormatComponent, isStandalone: true, selector: "nz-color-format", inputs: { format: "format", colorValue: "colorValue", clearColor: ["clearColor", "clearColor", booleanAttribute], nzDisabledAlpha: ["nzDisabledAlpha", "nzDisabledAlpha", booleanAttribute] }, outputs: { formatChange: "formatChange", nzOnFormatChange: "nzOnFormatChange" }, exportAs: ["NzColorFormat"], usesOnChanges: true, ngImport: i0, template: ` <div [formGroup]="validateForm" class="ant-color-picker-input-container"> <div class="ant-color-picker-format-select"> <nz-select formControlName="isFormat" nzBorderless nzSize="small"> <nz-option nzValue="hex" nzLabel="HEX" /> <nz-option nzValue="hsb" nzLabel="HSB" /> <nz-option nzValue="rgb" nzLabel="RGB" /> </nz-select> </div> <div class="ant-color-picker-input"> @switch (validateForm.controls.isFormat.value) { @case ('hex') { <div class="ant-color-picker-hex-input"> <nz-input-group nzPrefix="#" nzSize="small"> <input nz-input nzSize="small" formControlName="hex" /> </nz-input-group> </div> } @case ('hsb') { <div class="ant-color-picker-hsb-input"> <div class="ant-color-picker-steppers ant-color-picker-hsb-input"> <nz-input-number formControlName="hsbH" [nzMin]="0" [nzMax]="360" [nzStep]="1" [nzPrecision]="0" nzSize="small" /> </div> <div class="ant-color-picker-steppers ant-color-picker-hsb-input"> <nz-input-number formControlName="hsbS" [nzMin]="0" [nzMax]="100" [nzStep]="1" [nzFormatter]="formatterPercent" [nzParser]="parserPercent" nzSize="small" /> </div> <div class="ant-color-picker-steppers ant-color-picker-hsb-input"> <nz-input-number formControlName="hsbB" [nzMin]="0" [nzMax]="100" [nzStep]="1" [nzFormatter]="formatterPercent" [nzParser]="parserPercent" nzSize="small" /> </div> </div> } @default { <div class="ant-color-picker-rgb-input"> <div class="ant-color-picker-steppers ant-color-picker-rgb-input"> <nz-input-number formControlName="rgbR" [nzMin]="0" [nzMax]="255" [nzStep]="1" nzSize="small" /> </div> <div class="ant-color-picker-steppers ant-color-picker-rgb-input"> <nz-input-number formControlName="rgbG" [nzMin]="0" [nzMax]="255" [nzStep]="1" nzSize="small" /> </div> <div class="ant-color-picker-steppers ant-color-picker-rgb-input"> <nz-input-number formControlName="rgbB" [nzMin]="0" [nzMax]="255" [nzStep]="1" nzSize="small" /> </div> </div> } } </div> @if (!nzDisabledAlpha) { <div class="ant-color-picker-steppers ant-color-picker-alpha-input"> <nz-input-number formControlName="roundA" [nzMin]="0" [nzMax]="100" [nzStep]="1" [nzFormatter]="formatterPercent" [nzParser]="parserPercent" nzSize="small" /> </div> } </div> `, isInline: true, dependencies: [{ 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.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: NzSelectModule }, { kind: "component", type: i2.NzOptionComponent, selector: "nz-option", inputs: ["nzTitle", "nzLabel", "nzValue", "nzKey", "nzDisabled", "nzHide", "nzCustomContent"], exportAs: ["nzOption"] }, { kind: "component", type: i2.NzSelectComponent, selector: "nz-select", inputs: ["nzId", "nzSize", "nzStatus", "nzOptionHeightPx", "nzOptionOverflowSize", "nzDropdownClassName", "nzDropdownMatchSelectWidth", "nzDropdownStyle", "nzNotFoundContent", "nzPlaceHolder", "nzPlacement", "nzMaxTagCount", "nzDropdownRender", "nzCustomTemplate", "nzSuffixIcon", "nzClearIcon", "nzRemoveIcon", "nzMenuItemSelectedIcon", "nzTokenSeparators", "nzMaxTagPlaceholder", "nzMaxMultipleCount", "nzMode", "nzFilterOption", "compareWith", "nzAllowClear", "nzBorderless", "nzShowSearch", "nzLoading", "nzAutoFocus", "nzAutoClearSearchValue", "nzServerSearch", "nzDisabled", "nzOpen", "nzSelectOnTab", "nzBackdrop", "nzOptions", "nzShowArrow"], outputs: ["nzOnSearch", "nzScrollToBottom", "nzOpenChange", "nzBlur", "nzFocus"], exportAs: ["nzSelect"] }, { kind: "directive", type: NzInputDirective, selector: "input[nz-input],textarea[nz-input]", inputs: ["nzBorderless", "nzSize", "nzStepperless", "nzStatus", "disabled"], exportAs: ["nzInput"] }, { kind: "component", type: NzInputGroupComponent, selector: "nz-input-group", inputs: ["nzAddOnBeforeIcon", "nzAddOnAfterIcon", "nzPrefixIcon", "nzSuffixIcon", "nzAddOnBefore", "nzAddOnAfter", "nzPrefix", "nzStatus", "nzSuffix", "nzSize", "nzSearch", "nzCompact"], exportAs: ["nzInputGroup"] }, { kind: "component", type: NzInputNumberComponent, selector: "nz-input-number", inputs: ["nzSize", "nzMin", "nzMax", "nzParser", "nzPrecision", "nzPrecisionMode", "nzPlaceHolder", "nzStatus", "nzStep", "nzInputMode", "nzId", "nzDisabled", "nzReadOnly", "nzAutoFocus", "nzBorderless", "nzFormatter"], outputs: ["nzBlur", "nzFocus"], exportAs: ["nzInputNumber"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzColorFormatComponent, decorators: [{ type: Component, args: [{ selector: 'nz-color-format', exportAs: 'NzColorFormat', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ReactiveFormsModule, NzSelectModule, NzInputDirective, NzInputGroupComponent, NzInputNumberComponent], template: ` <div [formGroup]="validateForm" class="ant-color-picker-input-container"> <div class="ant-color-picker-format-select"> <nz-select formControlName="isFormat" nzBorderless nzSize="small"> <nz-option nzValue="hex" nzLabel="HEX" /> <nz-option nzValue="hsb" nzLabel="HSB" /> <nz-option nzValue="rgb" nzLabel="RGB" /> </nz-select> </div> <div class="ant-color-picker-input"> @switch (validateForm.controls.isFormat.value) { @case ('hex') { <div class="ant-color-picker-hex-input"> <nz-input-group nzPrefix="#" nzSize="small"> <input nz-input nzSize="small" formControlName="hex" /> </nz-input-group> </div> } @case ('hsb') { <div class="ant-color-picker-hsb-input"> <div class="ant-color-picker-steppers ant-color-picker-hsb-input"> <nz-input-number formControlName="hsbH" [nzMin]="0" [nzMax]="360" [nzStep]="1" [nzPrecision]="0" nzSize="small" /> </div> <div class="ant-color-picker-steppers ant-color-picker-hsb-input"> <nz-input-number formControlName="hsbS" [nzMin]="0" [nzMax]="100" [nzStep]="1" [nzFormatter]="formatterPercent" [nzParser]="parserPercent" nzSize="small" /> </div> <div class="ant-color-picker-steppers ant-color-picker-hsb-input"> <nz-input-number formControlName="hsbB" [nzMin]="0" [nzMax]="100" [nzStep]="1" [nzFormatter]="formatterPercent" [nzParser]="parserPercent" nzSize="small" /> </div> </div> } @default { <div class="ant-color-picker-rgb-input"> <div class="ant-color-picker-steppers ant-color-picker-rgb-input"> <nz-input-number formControlName="rgbR" [nzMin]="0" [nzMax]="255" [nzStep]="1" nzSize="small" /> </div> <div class="ant-color-picker-steppers ant-color-picker-rgb-input"> <nz-input-number formControlName="rgbG" [nzMin]="0" [nzMax]="255" [nzStep]="1" nzSize="small" /> </div> <div class="ant-color-picker-steppers ant-color-picker-rgb-input"> <nz-input-number formControlName="rgbB" [nzMin]="0" [nzMax]="255" [nzStep]="1" nzSize="small" /> </div> </div> } } </div> @if (!nzDisabledAlpha) { <div class="ant-color-picker-steppers ant-color-picker-alpha-input"> <nz-input-number formControlName="roundA" [nzMin]="0" [nzMax]="100" [nzStep]="1" [nzFormatter]="formatterPercent" [nzParser]="parserPercent" nzSize="small" /> </div> } </div> ` }] }], ctorParameters: () => [{ type: i1.FormBuilder }], propDecorators: { format: [{ type: Input }], colorValue: [{ type: Input }], clearColor: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzDisabledAlpha: [{ type: Input, args: [{ transform: booleanAttribute }] }], formatChange: [{ type: Output }], nzOnFormatChange: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-format.component.js","sourceRoot":"","sources":["../../../components/color-picker/color-format.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 {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  booleanAttribute\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormBuilder,\n  FormControl,\n  FormGroup,\n  ReactiveFormsModule,\n  ValidationErrors,\n  ValidatorFn\n} from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, filter, takeUntil } from 'rxjs/operators';\n\nimport { NzInputDirective, NzInputGroupComponent } from 'ng-zorro-antd/input';\nimport { NzInputNumberComponent } from 'ng-zorro-antd/input-number';\nimport { NzSelectModule } from 'ng-zorro-antd/select';\n\nimport { generateColor } from './src/util/util';\nimport { NzColorPickerFormatType, ValidFormKey } from './typings';\n\n@Component({\n  selector: 'nz-color-format',\n  exportAs: 'NzColorFormat',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [ReactiveFormsModule, NzSelectModule, NzInputDirective, NzInputGroupComponent, NzInputNumberComponent],\n  template: `\n    <div [formGroup]=\"validateForm\" class=\"ant-color-picker-input-container\">\n      <div class=\"ant-color-picker-format-select\">\n        <nz-select formControlName=\"isFormat\" nzBorderless nzSize=\"small\">\n          <nz-option nzValue=\"hex\" nzLabel=\"HEX\" />\n          <nz-option nzValue=\"hsb\" nzLabel=\"HSB\" />\n          <nz-option nzValue=\"rgb\" nzLabel=\"RGB\" />\n        </nz-select>\n      </div>\n\n      <div class=\"ant-color-picker-input\">\n        @switch (validateForm.controls.isFormat.value) {\n          @case ('hex') {\n            <div class=\"ant-color-picker-hex-input\">\n              <nz-input-group nzPrefix=\"#\" nzSize=\"small\">\n                <input nz-input nzSize=\"small\" formControlName=\"hex\" />\n              </nz-input-group>\n            </div>\n          }\n          @case ('hsb') {\n            <div class=\"ant-color-picker-hsb-input\">\n              <div class=\"ant-color-picker-steppers ant-color-picker-hsb-input\">\n                <nz-input-number\n                  formControlName=\"hsbH\"\n                  [nzMin]=\"0\"\n                  [nzMax]=\"360\"\n                  [nzStep]=\"1\"\n                  [nzPrecision]=\"0\"\n                  nzSize=\"small\"\n                />\n              </div>\n              <div class=\"ant-color-picker-steppers ant-color-picker-hsb-input\">\n                <nz-input-number\n                  formControlName=\"hsbS\"\n                  [nzMin]=\"0\"\n                  [nzMax]=\"100\"\n                  [nzStep]=\"1\"\n                  [nzFormatter]=\"formatterPercent\"\n                  [nzParser]=\"parserPercent\"\n                  nzSize=\"small\"\n                />\n              </div>\n              <div class=\"ant-color-picker-steppers ant-color-picker-hsb-input\">\n                <nz-input-number\n                  formControlName=\"hsbB\"\n                  [nzMin]=\"0\"\n                  [nzMax]=\"100\"\n                  [nzStep]=\"1\"\n                  [nzFormatter]=\"formatterPercent\"\n                  [nzParser]=\"parserPercent\"\n                  nzSize=\"small\"\n                />\n              </div>\n            </div>\n          }\n          @default {\n            <div class=\"ant-color-picker-rgb-input\">\n              <div class=\"ant-color-picker-steppers ant-color-picker-rgb-input\">\n                <nz-input-number formControlName=\"rgbR\" [nzMin]=\"0\" [nzMax]=\"255\" [nzStep]=\"1\" nzSize=\"small\" />\n              </div>\n              <div class=\"ant-color-picker-steppers ant-color-picker-rgb-input\">\n                <nz-input-number formControlName=\"rgbG\" [nzMin]=\"0\" [nzMax]=\"255\" [nzStep]=\"1\" nzSize=\"small\" />\n              </div>\n              <div class=\"ant-color-picker-steppers ant-color-picker-rgb-input\">\n                <nz-input-number formControlName=\"rgbB\" [nzMin]=\"0\" [nzMax]=\"255\" [nzStep]=\"1\" nzSize=\"small\" />\n              </div>\n            </div>\n          }\n        }\n      </div>\n\n      @if (!nzDisabledAlpha) {\n        <div class=\"ant-color-picker-steppers ant-color-picker-alpha-input\">\n          <nz-input-number\n            formControlName=\"roundA\"\n            [nzMin]=\"0\"\n            [nzMax]=\"100\"\n            [nzStep]=\"1\"\n            [nzFormatter]=\"formatterPercent\"\n            [nzParser]=\"parserPercent\"\n            nzSize=\"small\"\n          />\n        </div>\n      }\n    </div>\n  `\n})\nexport class NzColorFormatComponent implements OnChanges, OnInit, OnDestroy {\n  @Input() format: NzColorPickerFormatType | null = null;\n  @Input() colorValue: string = '';\n  @Input({ transform: booleanAttribute }) clearColor: boolean = false;\n  @Input({ transform: booleanAttribute }) nzDisabledAlpha: boolean = false;\n  @Output() readonly formatChange = new EventEmitter<{ color: string; format: NzColorPickerFormatType }>();\n  @Output() readonly nzOnFormatChange = new EventEmitter<NzColorPickerFormatType>();\n\n  private destroy$ = new Subject<void>();\n\n  validatorFn(): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n      const REGEXP = /^[0-9a-fA-F]{6}$/;\n      if (!control.value) {\n        return { error: true };\n      } else if (!REGEXP.test(control.value)) {\n        return { error: true };\n      }\n      return null;\n    };\n  }\n\n  validateForm: FormGroup<{\n    isFormat: FormControl<NzColorPickerFormatType | null>;\n    hex: FormControl<string | null>;\n    hsbH: FormControl<number>;\n    hsbS: FormControl<number>;\n    hsbB: FormControl<number>;\n    rgbR: FormControl<number>;\n    rgbG: FormControl<number>;\n    rgbB: FormControl<number>;\n    roundA: FormControl<number>;\n  }>;\n\n  formatterPercent = (value: number): string => `${value} %`;\n  parserPercent = (value: string): string => value.replace(' %', '');\n\n  constructor(private formBuilder: FormBuilder) {\n    this.validateForm = this.formBuilder.nonNullable.group({\n      isFormat: this.formBuilder.control<NzColorPickerFormatType>('hex'),\n      hex: this.formBuilder.control<string>('1677FF', this.validatorFn()),\n      hsbH: 215,\n      hsbS: 91,\n      hsbB: 100,\n      rgbR: 22,\n      rgbG: 119,\n      rgbB: 255,\n      roundA: 100\n    });\n  }\n\n  ngOnInit(): void {\n    this.validateForm.valueChanges\n      .pipe(\n        filter(() => this.validateForm.valid),\n        debounceTime(200),\n        distinctUntilChanged((prev, current) =>\n          Object.keys(prev).every(key => prev[key as ValidFormKey] === current[key as ValidFormKey])\n        ),\n        takeUntil(this.destroy$)\n      )\n      .subscribe(value => {\n        let color = '';\n        switch (value.isFormat) {\n          case 'hsb':\n            color = generateColor({\n              h: Number(value.hsbH),\n              s: Number(value.hsbS) / 100,\n              b: Number(value.hsbB) / 100,\n              a: Number(value.roundA) / 100\n            }).toHsbString();\n            break;\n          case 'rgb':\n            color = generateColor({\n              r: Number(value.rgbR),\n              g: Number(value.rgbG),\n              b: Number(value.rgbB),\n              a: Number(value.roundA) / 100\n            }).toRgbString();\n            break;\n          default:\n            const hex = generateColor(value.hex as NzColorPickerFormatType);\n            const hexColor = generateColor({\n              r: hex.r,\n              g: hex.g,\n              b: hex.b,\n              a: Number(value.roundA) / 100\n            });\n            color = hexColor.getAlpha() < 1 ? hexColor.toHex8String() : hexColor.toHexString();\n            break;\n        }\n        this.formatChange.emit({ color, format: value.isFormat || this.format || 'hex' });\n      });\n\n    this.validateForm\n      .get('isFormat')\n      ?.valueChanges.pipe(takeUntil(this.destroy$))\n      .subscribe(value => {\n        this.nzOnFormatChange.emit(value as NzColorPickerFormatType);\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { colorValue, format, clearColor } = changes;\n    if (colorValue) {\n      const colorValue = {\n        hex: generateColor(this.colorValue).toHex(),\n        hsbH: Math.round(generateColor(this.colorValue).toHsb().h),\n        hsbS: Math.round(generateColor(this.colorValue).toHsb().s * 100),\n        hsbB: Math.round(generateColor(this.colorValue).toHsb().b * 100),\n        rgbR: Math.round(generateColor(this.colorValue).r),\n        rgbG: Math.round(generateColor(this.colorValue).g),\n        rgbB: Math.round(generateColor(this.colorValue).b),\n        roundA: Math.round(generateColor(this.colorValue).roundA * 100)\n      };\n      this.validateForm.patchValue(colorValue);\n    }\n\n    if (format && this.format) {\n      this.validateForm.get('isFormat')?.patchValue(this.format);\n    }\n\n    if (clearColor && this.clearColor) {\n      this.validateForm.get('roundA')?.patchValue(0);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n}\n"]}