UNPKG

ng-zorro-antd

Version:

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

347 lines 30 kB
/** * @fileoverview added by tsickle * Generated from: nz-form-control.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; /** * @license * Copyright Alibaba.com All Rights Reserved. * * 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, ChangeDetectorRef, Component, ContentChild, ElementRef, Host, Input, Optional, Renderer2, ViewEncapsulation } from '@angular/core'; import { FormControl, FormControlDirective, FormControlName, NgControl, NgModel } from '@angular/forms'; import { Subscription } from 'rxjs'; import { startWith } from 'rxjs/operators'; import { helpMotion, toBoolean, NzUpdateHostClassService } from 'ng-zorro-antd/core'; import { NzColDirective, NzRowDirective } from 'ng-zorro-antd/grid'; import { NzFormItemComponent } from './nz-form-item.component'; var NzFormControlComponent = /** @class */ (function (_super) { tslib_1.__extends(NzFormControlComponent, _super); function NzFormControlComponent(nzUpdateHostClassService, elementRef, nzFormItemComponent, nzRowDirective, cdr, renderer) { var _this = _super.call(this, nzUpdateHostClassService, elementRef, nzFormItemComponent || nzRowDirective, renderer) || this; _this.nzFormItemComponent = nzFormItemComponent; _this.cdr = cdr; _this._hasFeedback = false; _this.validateChanges = Subscription.EMPTY; _this.status = null; _this.controlClassMap = {}; renderer.addClass(elementRef.nativeElement, 'ant-form-item-control-wrapper'); return _this; } Object.defineProperty(NzFormControlComponent.prototype, "nzHasFeedback", { get: /** * @return {?} */ function () { return this._hasFeedback; }, set: /** * @param {?} value * @return {?} */ function (value) { this._hasFeedback = toBoolean(value); this.setControlClassMap(); }, enumerable: true, configurable: true }); Object.defineProperty(NzFormControlComponent.prototype, "nzValidateStatus", { set: /** * @param {?} value * @return {?} */ function (value) { if (value instanceof FormControl || value instanceof NgModel) { 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(); } }, enumerable: true, configurable: true }); /** * @return {?} */ NzFormControlComponent.prototype.removeSubscribe = /** * @return {?} */ function () { this.validateChanges.unsubscribe(); }; /** * @return {?} */ NzFormControlComponent.prototype.watchControl = /** * @return {?} */ function () { var _this = this; 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 {?} */ function () { _this.setControlClassMap(); _this.cdr.markForCheck(); })); } }; /** * @param {?} status * @return {?} */ NzFormControlComponent.prototype.validateControlStatus = /** * @param {?} status * @return {?} */ function (status) { return (/** @type {?} */ ((!!this.validateControl && (this.validateControl.dirty || this.validateControl.touched) && this.validateControl.status === status))); }; /** * @return {?} */ NzFormControlComponent.prototype.setControlClassMap = /** * @return {?} */ function () { var _a; if (this.validateString === 'warning') { this.status = 'warning'; this.iconType = 'exclamation-circle-fill'; } else if (this.validateString === 'validating' || this.validateString === 'pending' || this.validateControlStatus('PENDING')) { this.status = 'validating'; this.iconType = 'loading'; } else if (this.validateString === 'error' || this.validateControlStatus('INVALID')) { this.status = 'error'; this.iconType = 'close-circle-fill'; } else if (this.validateString === 'success' || this.validateControlStatus('VALID')) { this.status = 'success'; this.iconType = 'check-circle-fill'; } else { this.status = null; this.iconType = ''; } if (this.hasTips) { this.nzFormItemComponent.setWithHelpViaTips(this.showErrorTip); } this.controlClassMap = (_a = {}, _a["has-warning"] = this.status === 'warning', _a["is-validating"] = this.status === 'validating', _a["has-error"] = this.status === 'error', _a["has-success"] = this.status === 'success', _a["has-feedback"] = this.nzHasFeedback && this.status, _a); }; Object.defineProperty(NzFormControlComponent.prototype, "hasTips", { get: /** * @return {?} */ function () { return !!(this.nzSuccessTip || this.nzWarningTip || this.nzErrorTip || this.nzValidatingTip); }, enumerable: true, configurable: true }); Object.defineProperty(NzFormControlComponent.prototype, "showSuccessTip", { get: /** * @return {?} */ function () { return this.status === 'success' && !!this.nzSuccessTip; }, enumerable: true, configurable: true }); Object.defineProperty(NzFormControlComponent.prototype, "showWarningTip", { get: /** * @return {?} */ function () { return this.status === 'warning' && !!this.nzWarningTip; }, enumerable: true, configurable: true }); Object.defineProperty(NzFormControlComponent.prototype, "showErrorTip", { get: /** * @return {?} */ function () { return this.status === 'error' && !!this.nzErrorTip; }, enumerable: true, configurable: true }); Object.defineProperty(NzFormControlComponent.prototype, "showValidatingTip", { get: /** * @return {?} */ function () { return this.status === 'validating' && !!this.nzValidatingTip; }, enumerable: true, configurable: true }); Object.defineProperty(NzFormControlComponent.prototype, "showInnerTip", { get: /** * @return {?} */ function () { return this.showSuccessTip || this.showWarningTip || this.showErrorTip || this.showValidatingTip; }, enumerable: true, configurable: true }); /** * @return {?} */ NzFormControlComponent.prototype.ngOnInit = /** * @return {?} */ function () { _super.prototype.ngOnInit.call(this); this.setControlClassMap(); }; /** * @return {?} */ NzFormControlComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.removeSubscribe(); _super.prototype.ngOnDestroy.call(this); }; /** * @return {?} */ NzFormControlComponent.prototype.ngAfterContentInit = /** * @return {?} */ function () { if (!this.validateControl && !this.validateString) { if (this.defaultValidateControl instanceof FormControlDirective) { this.nzValidateStatus = this.defaultValidateControl.control; } else { this.nzValidateStatus = this.defaultValidateControl; } } }; /** * @return {?} */ NzFormControlComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { _super.prototype.ngAfterViewInit.call(this); }; NzFormControlComponent.decorators = [ { type: Component, args: [{ selector: 'nz-form-control', exportAs: 'nzFormControl', preserveWhitespaces: false, animations: [helpMotion], 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 [nzType]=\"iconType\"></i>\n </span>\n </span>\n <div class=\"ant-form-explain\" *ngIf=\"showSuccessTip || showWarningTip || showErrorTip || showValidatingTip\">\n <div @helpMotion>\n <ng-container *ngIf=\"showSuccessTip\">\n <ng-container *nzStringTemplateOutlet=\"nzSuccessTip;context:{$implicit:validateControl};\">{{ nzSuccessTip }}</ng-container>\n </ng-container>\n <ng-container *ngIf=\"showWarningTip\">\n <ng-container *nzStringTemplateOutlet=\"nzWarningTip;context:{$implicit:validateControl};\">{{ nzWarningTip }}</ng-container>\n </ng-container>\n <ng-container *ngIf=\"showErrorTip\">\n <ng-container *nzStringTemplateOutlet=\"nzErrorTip;context:{$implicit:validateControl};\">{{ nzErrorTip }}</ng-container>\n </ng-container>\n <ng-container *ngIf=\"showValidatingTip\">\n <ng-container *nzStringTemplateOutlet=\"nzValidatingTip;context:{$implicit:validateControl};\">{{ nzValidatingTip }}</ng-container>\n </ng-container>\n </div>\n </div>\n <ng-content *ngIf=\"!hasTips\" select=\"nz-form-explain\"></ng-content>\n <ng-content *ngIf=\"!nzExtra\" select=\"nz-form-extra\"></ng-content>\n <div class=\"ant-form-extra\" *ngIf=\"nzExtra\">\n <ng-container *nzStringTemplateOutlet=\"nzExtra\">{{ nzExtra }}</ng-container>\n </div>\n</div>", styles: ["\n nz-form-control {\n display: block;\n }\n form .has-feedback .ant-input-suffix i {\n margin-right: 18px;\n }\n "] }] } ]; /** @nocollapse */ NzFormControlComponent.ctorParameters = function () { return [ { 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, { static: false },] }], nzSuccessTip: [{ type: Input }], nzWarningTip: [{ type: Input }], nzErrorTip: [{ type: Input }], nzValidatingTip: [{ type: Input }], nzExtra: [{ type: Input }], nzHasFeedback: [{ type: Input }], nzValidateStatus: [{ type: Input }] }; return NzFormControlComponent; }(NzColDirective)); export { NzFormControlComponent }; if (false) { /** * @type {?} * @private */ NzFormControlComponent.prototype._hasFeedback; /** * @type {?} * @private */ NzFormControlComponent.prototype.validateChanges; /** * @type {?} * @private */ NzFormControlComponent.prototype.validateString; /** @type {?} */ NzFormControlComponent.prototype.validateControl; /** @type {?} */ NzFormControlComponent.prototype.status; /** @type {?} */ NzFormControlComponent.prototype.controlClassMap; /** @type {?} */ NzFormControlComponent.prototype.iconType; /** @type {?} */ NzFormControlComponent.prototype.defaultValidateControl; /** @type {?} */ NzFormControlComponent.prototype.nzSuccessTip; /** @type {?} */ NzFormControlComponent.prototype.nzWarningTip; /** @type {?} */ NzFormControlComponent.prototype.nzErrorTip; /** @type {?} */ NzFormControlComponent.prototype.nzValidatingTip; /** @type {?} */ NzFormControlComponent.prototype.nzExtra; /** * @type {?} * @private */ NzFormControlComponent.prototype.nzFormItemComponent; /** * @type {?} * @private */ NzFormControlComponent.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-form-control.component.js","sourceRoot":"ng://ng-zorro-antd/form/","sources":["nz-form-control.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\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  AfterContentInit,\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ElementRef,\n  Host,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Renderer2,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { FormControl, FormControlDirective, FormControlName, NgControl, NgModel } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { startWith } from 'rxjs/operators';\n\nimport { helpMotion, toBoolean, NgClassType, NzUpdateHostClassService } from 'ng-zorro-antd/core';\nimport { NzColDirective, NzRowDirective } from 'ng-zorro-antd/grid';\nimport { NzFormItemComponent } from './nz-form-item.component';\n\nexport type NzFormControlStatusType = 'warning' | 'validating' | 'error' | 'success' | null;\n\n@Component({\n  selector: 'nz-form-control',\n  exportAs: 'nzFormControl',\n  preserveWhitespaces: false,\n  animations: [helpMotion],\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      form .has-feedback .ant-input-suffix i {\n        margin-right: 18px;\n      }\n    `\n  ]\n})\nexport class NzFormControlComponent extends NzColDirective\n  implements OnDestroy, OnInit, AfterContentInit, AfterViewInit, OnDestroy {\n  private _hasFeedback = false;\n  private validateChanges: Subscription = Subscription.EMPTY;\n  private validateString: string | null;\n  validateControl: FormControl | NgModel | null;\n  status: NzFormControlStatusType = null;\n  controlClassMap: NgClassType = {};\n  iconType: string;\n  @ContentChild(NgControl, { static: false }) defaultValidateControl: FormControlName | FormControlDirective;\n  @Input() nzSuccessTip: string | TemplateRef<{ $implicit: FormControl | NgModel }>;\n  @Input() nzWarningTip: string | TemplateRef<{ $implicit: FormControl | NgModel }>;\n  @Input() nzErrorTip: string | TemplateRef<{ $implicit: FormControl | NgModel }>;\n  @Input() nzValidatingTip: string | TemplateRef<{ $implicit: FormControl | NgModel }>;\n  @Input() nzExtra: string | TemplateRef<void>;\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 | NgModel) {\n    if (value instanceof FormControl || value instanceof NgModel) {\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    this.validateChanges.unsubscribe();\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(startWith(null)).subscribe(() => {\n        this.setControlClassMap();\n        this.cdr.markForCheck();\n      });\n    }\n  }\n\n  validateControlStatus(status: string): boolean {\n    return (!!this.validateControl &&\n      (this.validateControl.dirty || this.validateControl.touched) &&\n      this.validateControl.status === status) as boolean;\n  }\n\n  setControlClassMap(): void {\n    if (this.validateString === 'warning') {\n      this.status = 'warning';\n      this.iconType = 'exclamation-circle-fill';\n    } else if (\n      this.validateString === 'validating' ||\n      this.validateString === 'pending' ||\n      this.validateControlStatus('PENDING')\n    ) {\n      this.status = 'validating';\n      this.iconType = 'loading';\n    } else if (this.validateString === 'error' || this.validateControlStatus('INVALID')) {\n      this.status = 'error';\n      this.iconType = 'close-circle-fill';\n    } else if (this.validateString === 'success' || this.validateControlStatus('VALID')) {\n      this.status = 'success';\n      this.iconType = 'check-circle-fill';\n    } else {\n      this.status = null;\n      this.iconType = '';\n    }\n    if (this.hasTips) {\n      this.nzFormItemComponent.setWithHelpViaTips(this.showErrorTip);\n    }\n    this.controlClassMap = {\n      [`has-warning`]: this.status === 'warning',\n      [`is-validating`]: this.status === 'validating',\n      [`has-error`]: this.status === 'error',\n      [`has-success`]: this.status === 'success',\n      [`has-feedback`]: this.nzHasFeedback && this.status\n    };\n  }\n\n  get hasTips(): boolean {\n    return !!(this.nzSuccessTip || this.nzWarningTip || this.nzErrorTip || this.nzValidatingTip);\n  }\n\n  get showSuccessTip(): boolean {\n    return this.status === 'success' && !!this.nzSuccessTip;\n  }\n\n  get showWarningTip(): boolean {\n    return this.status === 'warning' && !!this.nzWarningTip;\n  }\n\n  get showErrorTip(): boolean {\n    return this.status === 'error' && !!this.nzErrorTip;\n  }\n\n  get showValidatingTip(): boolean {\n    return this.status === 'validating' && !!this.nzValidatingTip;\n  }\n\n  get showInnerTip(): boolean {\n    return this.showSuccessTip || this.showWarningTip || this.showErrorTip || this.showValidatingTip;\n  }\n\n  constructor(\n    nzUpdateHostClassService: NzUpdateHostClassService,\n    elementRef: ElementRef,\n    @Optional() @Host() private nzFormItemComponent: NzFormItemComponent,\n    @Optional() @Host() nzRowDirective: NzRowDirective,\n    private cdr: ChangeDetectorRef,\n    renderer: Renderer2\n  ) {\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.validateControl && !this.validateString) {\n      if (this.defaultValidateControl instanceof FormControlDirective) {\n        this.nzValidateStatus = this.defaultValidateControl.control;\n      } else {\n        this.nzValidateStatus = this.defaultValidateControl;\n      }\n    }\n  }\n\n  ngAfterViewInit(): void {\n    super.ngAfterViewInit();\n  }\n}\n"]}