ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
205 lines • 19.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ElementRef, Host, Input, Optional, Renderer2, ViewEncapsulation } from '@angular/core';
import { FormControl, FormControlName, NgControl } from '@angular/forms';
import { startWith } from 'rxjs/operators';
import { NzUpdateHostClassService } from '../core/services/update-host-class.service';
import { toBoolean } from '../core/util/convert';
import { NzColDirective } from '../grid/nz-col.directive';
import { NzRowDirective } from '../grid/nz-row.directive';
import { NzFormItemComponent } from './nz-form-item.component';
export class NzFormControlComponent extends NzColDirective {
/**
* @param {?} nzUpdateHostClassService
* @param {?} elementRef
* @param {?} nzFormItemComponent
* @param {?} nzRowDirective
* @param {?} cdr
* @param {?} renderer
*/
constructor(nzUpdateHostClassService, elementRef, nzFormItemComponent, nzRowDirective, cdr, renderer) {
super(nzUpdateHostClassService, elementRef, nzFormItemComponent || nzRowDirective, renderer);
this.cdr = cdr;
this._hasFeedback = false;
this.controlClassMap = {};
renderer.addClass(elementRef.nativeElement, 'ant-form-item-control-wrapper');
}
/**
* @param {?} value
* @return {?}
*/
set nzHasFeedback(value) {
this._hasFeedback = toBoolean(value);
this.setControlClassMap();
}
/**
* @return {?}
*/
get nzHasFeedback() {
return this._hasFeedback;
}
/**
* @param {?} value
* @return {?}
*/
set nzValidateStatus(value) {
if (value instanceof FormControl) {
this.validateControl = value;
this.validateString = null;
this.watchControl();
}
else if (value instanceof FormControlName) {
this.validateControl = value.control;
this.validateString = null;
this.watchControl();
}
else {
this.validateString = value;
this.validateControl = null;
this.setControlClassMap();
}
}
/**
* @return {?}
*/
removeSubscribe() {
if (this.validateChanges) {
this.validateChanges.unsubscribe();
this.validateChanges = null;
}
}
/**
* @return {?}
*/
watchControl() {
this.removeSubscribe();
/** miss detect https://github.com/angular/angular/issues/10887 **/
if (this.validateControl && this.validateControl.statusChanges) {
this.validateChanges = this.validateControl.statusChanges.pipe(startWith(null)).subscribe((/**
* @return {?}
*/
() => {
this.setControlClassMap();
this.cdr.markForCheck();
}));
}
}
/**
* @param {?} status
* @return {?}
*/
validateControlStatus(status) {
return this.validateControl && (this.validateControl.dirty || this.validateControl.touched) && (this.validateControl.status === status);
}
/**
* @return {?}
*/
setControlClassMap() {
this.controlClassMap = {
[`has-warning`]: this.validateString === 'warning',
[`is-validating`]: this.validateString === 'validating' || this.validateString === 'pending' || this.validateControlStatus('PENDING'),
[`has-error`]: this.validateString === 'error' || this.validateControlStatus('INVALID'),
[`has-success`]: this.validateString === 'success' || this.validateControlStatus('VALID'),
[`has-feedback`]: this.nzHasFeedback
};
if (this.controlClassMap['has-warning']) {
this.iconType = 'exclamation-circle-fill';
}
else if (this.controlClassMap['is-validating']) {
this.iconType = 'loading';
}
else if (this.controlClassMap['has-error']) {
this.iconType = 'close-circle-fill';
}
else if (this.controlClassMap['has-success']) {
this.iconType = 'check-circle-fill';
}
else {
this.iconType = '';
}
}
/**
* @return {?}
*/
ngOnInit() {
super.ngOnInit();
this.setControlClassMap();
}
/**
* @return {?}
*/
ngOnDestroy() {
this.removeSubscribe();
super.ngOnDestroy();
}
/**
* @return {?}
*/
ngAfterContentInit() {
if (this.defaultValidateControl && (!this.validateControl) && (!this.validateString)) {
this.nzValidateStatus = this.defaultValidateControl;
}
}
/**
* @return {?}
*/
ngAfterViewInit() {
super.ngAfterViewInit();
}
}
NzFormControlComponent.decorators = [
{ type: Component, args: [{
selector: 'nz-form-control',
preserveWhitespaces: false,
encapsulation: ViewEncapsulation.None,
changeDetection: ChangeDetectionStrategy.OnPush,
providers: [NzUpdateHostClassService],
template: "<div class=\"ant-form-item-control\" [ngClass]=\"controlClassMap\">\n <span class=\"ant-form-item-children\">\n <ng-content></ng-content>\n <span class=\"ant-form-item-children-icon\">\n <i *ngIf=\"nzHasFeedback && iconType\" nz-icon [type]=\"iconType\"></i>\n </span>\n </span>\n <ng-content select=\"nz-form-explain\"></ng-content>\n</div>",
styles: [`
nz-form-control {
display: block;
}
`]
}] }
];
/** @nocollapse */
NzFormControlComponent.ctorParameters = () => [
{ type: NzUpdateHostClassService },
{ type: ElementRef },
{ type: NzFormItemComponent, decorators: [{ type: Optional }, { type: Host }] },
{ type: NzRowDirective, decorators: [{ type: Optional }, { type: Host }] },
{ type: ChangeDetectorRef },
{ type: Renderer2 }
];
NzFormControlComponent.propDecorators = {
defaultValidateControl: [{ type: ContentChild, args: [NgControl,] }],
nzHasFeedback: [{ type: Input }],
nzValidateStatus: [{ type: Input }]
};
if (false) {
/**
* @type {?}
* @private
*/
NzFormControlComponent.prototype._hasFeedback;
/** @type {?} */
NzFormControlComponent.prototype.validateChanges;
/** @type {?} */
NzFormControlComponent.prototype.validateString;
/** @type {?} */
NzFormControlComponent.prototype.controlClassMap;
/** @type {?} */
NzFormControlComponent.prototype.iconType;
/** @type {?} */
NzFormControlComponent.prototype.validateControl;
/** @type {?} */
NzFormControlComponent.prototype.defaultValidateControl;
/**
* @type {?}
* @private
*/
NzFormControlComponent.prototype.cdr;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-form-control.component.js","sourceRoot":"ng://ng-zorro-antd/","sources":["form/nz-form-control.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit, AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ElementRef,\n  Host,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional, Renderer2,\n  ViewEncapsulation\n} from '@angular/core';\nimport { FormControl, FormControlName, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { startWith } from 'rxjs/operators';\nimport { NzUpdateHostClassService } from '../core/services/update-host-class.service';\nimport { NgClassType } from '../core/types/ng-class';\nimport { toBoolean } from '../core/util/convert';\nimport { NzColDirective } from '../grid/nz-col.directive';\nimport { NzRowDirective } from '../grid/nz-row.directive';\nimport { NzFormItemComponent } from './nz-form-item.component';\n\n@Component({\n  selector           : 'nz-form-control',\n  preserveWhitespaces: false,\n  encapsulation      : ViewEncapsulation.None,\n  changeDetection    : ChangeDetectionStrategy.OnPush,\n  providers          : [ NzUpdateHostClassService ],\n  templateUrl        : './nz-form-control.component.html',\n  styles             : [\n      `\n      nz-form-control {\n        display: block;\n      }\n    `\n  ]\n})\nexport class NzFormControlComponent extends NzColDirective implements OnDestroy, OnInit, AfterContentInit, AfterViewInit, OnDestroy {\n  private _hasFeedback = false;\n  validateChanges: Subscription;\n  validateString: string;\n  controlClassMap: NgClassType = {};\n  iconType: string;\n  validateControl: FormControl;\n  @ContentChild(NgControl) defaultValidateControl: FormControlName;\n\n  @Input()\n  set nzHasFeedback(value: boolean) {\n    this._hasFeedback = toBoolean(value);\n    this.setControlClassMap();\n  }\n\n  get nzHasFeedback(): boolean {\n    return this._hasFeedback;\n  }\n\n  @Input()\n  set nzValidateStatus(value: string | FormControl | FormControlName) {\n    if (value instanceof FormControl) {\n      this.validateControl = value;\n      this.validateString = null;\n      this.watchControl();\n    } else if (value instanceof FormControlName) {\n      this.validateControl = value.control;\n      this.validateString = null;\n      this.watchControl();\n    } else {\n      this.validateString = value;\n      this.validateControl = null;\n      this.setControlClassMap();\n    }\n  }\n\n  removeSubscribe(): void {\n    if (this.validateChanges) {\n      this.validateChanges.unsubscribe();\n      this.validateChanges = null;\n    }\n  }\n\n  watchControl(): void {\n    this.removeSubscribe();\n    /** miss detect https://github.com/angular/angular/issues/10887 **/\n    if (this.validateControl && this.validateControl.statusChanges) {\n      this.validateChanges = this.validateControl.statusChanges.pipe(\n        startWith(null)\n      ).subscribe(() => {\n        this.setControlClassMap();\n        this.cdr.markForCheck();\n      });\n    }\n  }\n\n  validateControlStatus(status: string): boolean {\n    return this.validateControl && (this.validateControl.dirty || this.validateControl.touched) && (this.validateControl.status === status);\n  }\n\n  setControlClassMap(): void {\n    this.controlClassMap = {\n      [ `has-warning` ]  : this.validateString === 'warning',\n      [ `is-validating` ]: this.validateString === 'validating' || this.validateString === 'pending' || this.validateControlStatus('PENDING'),\n      [ `has-error` ]    : this.validateString === 'error' || this.validateControlStatus('INVALID'),\n      [ `has-success` ]  : this.validateString === 'success' || this.validateControlStatus('VALID'),\n      [ `has-feedback` ] : this.nzHasFeedback\n    };\n\n    if (this.controlClassMap[ 'has-warning' ]) {\n      this.iconType = 'exclamation-circle-fill';\n    } else if (this.controlClassMap[ 'is-validating' ]) {\n      this.iconType = 'loading';\n    } else if (this.controlClassMap[ 'has-error' ]) {\n      this.iconType = 'close-circle-fill';\n    } else if (this.controlClassMap[ 'has-success' ]) {\n      this.iconType = 'check-circle-fill';\n    } else {\n      this.iconType = '';\n    }\n  }\n\n  constructor(nzUpdateHostClassService: NzUpdateHostClassService, elementRef: ElementRef, @Optional() @Host() nzFormItemComponent: NzFormItemComponent, @Optional() @Host() nzRowDirective: NzRowDirective, private cdr: ChangeDetectorRef, renderer: Renderer2) {\n    super(nzUpdateHostClassService, elementRef, nzFormItemComponent || nzRowDirective, renderer);\n    renderer.addClass(elementRef.nativeElement, 'ant-form-item-control-wrapper');\n  }\n\n  ngOnInit(): void {\n    super.ngOnInit();\n    this.setControlClassMap();\n  }\n\n  ngOnDestroy(): void {\n    this.removeSubscribe();\n    super.ngOnDestroy();\n  }\n\n  ngAfterContentInit(): void {\n    if (this.defaultValidateControl && (!this.validateControl) && (!this.validateString)) {\n      this.nzValidateStatus = this.defaultValidateControl;\n    }\n  }\n\n  ngAfterViewInit(): void {\n    super.ngAfterViewInit();\n  }\n}\n"]}