UNPKG

ng-zorro-antd

Version:

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

397 lines 29.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input } from '@angular/core'; import { isNotNil } from '../core/util/check'; export class NzProgressComponent { constructor() { this._gapDegree = 0; this._gapPosition = 'top'; this._percent = 0; this._status = 'normal'; this._cacheStatus = 'normal'; this._strokeLinecap = 'round'; this._strokeWidth = 8; this._size = 'default'; this._type = 'line'; this._format = (/** * @param {?} percent * @return {?} */ (percent) => `${percent}%`); this.isStatusSet = false; this.isStrokeWidthSet = false; this.isFormatSet = false; this.isGapDegreeSet = false; this.isGapPositionSet = false; this.statusColorMap = { normal: '#108ee9', exception: '#ff5500', success: '#87d068' }; this.nzShowInfo = true; this.nzWidth = 132; this.nzSuccessPercent = 0; } /** * @param {?} value * @return {?} */ set nzSize(value) { this._size = value; if (this.nzSize === 'small' && !this.isStrokeWidthSet) { this._strokeWidth = 6; } } /** * @return {?} */ get nzSize() { return this._size; } /** * @param {?} value * @return {?} */ set nzFormat(value) { if (isNotNil(value)) { this._format = value; this.isFormatSet = true; } } /** * @return {?} */ get nzFormat() { return this._format; } /** * @param {?} value * @return {?} */ set nzPercent(value) { this._percent = value; if (isNotNil(value)) { /** @type {?} */ const fillAll = parseInt(value.toString(), 10) >= 100; if (fillAll && !this.isStatusSet) { this._status = 'success'; } else { this._status = this._cacheStatus; } this.updatePathStyles(); this.updateIcon(); } } /** * @return {?} */ get nzPercent() { return this._percent; } /** * @param {?} value * @return {?} */ set nzStrokeWidth(value) { if (isNotNil(value)) { this._strokeWidth = value; this.isStrokeWidthSet = true; this.updatePathStyles(); } } /** * @return {?} */ get nzStrokeWidth() { return this._strokeWidth; } /** * @param {?} value * @return {?} */ set nzStatus(value) { if (isNotNil(value)) { this._status = value; this._cacheStatus = value; this.isStatusSet = true; this.updateIcon(); } } /** * @return {?} */ get nzStatus() { return this._status; } /** * @param {?} value * @return {?} */ set nzType(value) { this._type = value; if (!this.isStrokeWidthSet) { if (this.nzType !== 'line') { this._strokeWidth = 6; } } if (this.nzType === 'dashboard') { if (!this.isGapPositionSet) { this._gapPosition = 'bottom'; } if (!this.isGapDegreeSet) { this._gapDegree = 75; } } this.updateIcon(); this.updatePathStyles(); } /** * @return {?} */ get nzType() { return this._type; } /** * @param {?} value * @return {?} */ set nzGapDegree(value) { if (isNotNil(value)) { this._gapDegree = value; this.isGapDegreeSet = true; this.updatePathStyles(); } } /** * @return {?} */ get nzGapDegree() { return this._gapDegree; } /** * @param {?} value * @return {?} */ set nzGapPosition(value) { if (isNotNil(value)) { this._gapPosition = value; this.isGapPositionSet = true; this.updatePathStyles(); } } /** * @return {?} */ get nzGapPosition() { return this._gapPosition; } /** * @param {?} value * @return {?} */ set nzStrokeLinecap(value) { this._strokeLinecap = value; this.updatePathStyles(); } /** * @return {?} */ get nzStrokeLinecap() { return this._strokeLinecap; } /** * @return {?} */ get isCirCleStyle() { return this.nzType === 'circle' || this.nzType === 'dashboard'; } /** * @return {?} */ updatePathStyles() { /** @type {?} */ const radius = 50 - (this.nzStrokeWidth / 2); /** @type {?} */ let beginPositionX = 0; /** @type {?} */ let beginPositionY = -radius; /** @type {?} */ let endPositionX = 0; /** @type {?} */ let endPositionY = radius * -2; switch (this.nzGapPosition) { case 'left': beginPositionX = -radius; beginPositionY = 0; endPositionX = radius * 2; endPositionY = 0; break; case 'right': beginPositionX = radius; beginPositionY = 0; endPositionX = radius * -2; endPositionY = 0; break; case 'bottom': beginPositionY = radius; endPositionY = radius * 2; break; default: } this.pathString = `M 50,50 m ${beginPositionX},${beginPositionY} a ${radius},${radius} 0 1 1 ${endPositionX},${-endPositionY} a ${radius},${radius} 0 1 1 ${-endPositionX},${endPositionY}`; /** @type {?} */ const len = Math.PI * 2 * radius; this.trailPathStyle = { strokeDasharray: `${len - this.nzGapDegree}px ${len}px`, strokeDashoffset: `-${this.nzGapDegree / 2}px`, transition: 'stroke-dashoffset .3s ease 0s, stroke-dasharray .3s ease 0s, stroke .3s' }; this.strokePathStyle = { strokeDasharray: `${(this.nzPercent / 100) * (len - this.nzGapDegree)}px ${len}px`, strokeDashoffset: `-${this.nzGapDegree / 2}px`, transition: 'stroke-dashoffset .3s ease 0s, stroke-dasharray .3s ease 0s, stroke .3s, stroke-width .06s ease .3s' // eslint-disable-line }; } /** * @return {?} */ updateIcon() { /** @type {?} */ const isCircle = (this.nzType === 'circle' || this.nzType === 'dashboard'); /** @type {?} */ let ret = ''; if (this.nzStatus === 'success') { ret = 'check'; } if (this.nzStatus === 'exception') { ret = 'close'; } if (ret) { if (!isCircle) { ret += '-circle'; this.iconTheme = 'fill'; } else { this.iconTheme = 'outline'; } } this.icon = ret; } /** * @return {?} */ ngOnInit() { this.updatePathStyles(); this.updateIcon(); } } NzProgressComponent.decorators = [ { type: Component, args: [{ selector: 'nz-progress', preserveWhitespaces: false, template: "<ng-template #progressInfoTemplate>\n <span class=\"ant-progress-text\" *ngIf=\"nzShowInfo\">\n <ng-container *ngIf=\"(nzStatus=='exception')||(nzStatus=='success')&&(!isFormatSet); else formatTemplate\">\n <!-- Theme is handled in type here. -->\n <i nz-icon [type]=\"icon\" [theme]=\"iconTheme\"></i>\n </ng-container>\n <ng-template #formatTemplate>\n {{ nzFormat(nzPercent) }}\n </ng-template>\n </span>\n</ng-template>\n<div [ngClass]=\"'ant-progress ant-progress-status-'+nzStatus\"\n [class.ant-progress-line]=\"nzType=='line'\"\n [class.ant-progress-small]=\"nzSize=='small'\"\n [class.ant-progress-show-info]=\"nzShowInfo\"\n [class.ant-progress-circle]=\"isCirCleStyle\">\n <div *ngIf=\"nzType=='line'\">\n <div class=\"ant-progress-outer\">\n <div class=\"ant-progress-inner\">\n <div class=\"ant-progress-bg\"\n [style.width.%]=\"nzPercent\"\n [style.border-radius]=\"nzStrokeLinecap === 'round' ? '100px' : '0'\"\n [style.background]=\"nzStrokeColor\"\n [style.height.px]=\"nzStrokeWidth\">\n </div>\n <div class=\"ant-progress-success-bg\"\n [style.width.%]=\"nzSuccessPercent\"\n [style.border-radius]=\"nzStrokeLinecap === 'round' ? '100px' : '0'\"\n [style.height.px]=\"nzStrokeWidth\"></div>\n </div>\n </div>\n <ng-template [ngTemplateOutlet]=\"progressInfoTemplate\"></ng-template>\n </div>\n <div\n [style.width.px]=\"this.nzWidth\"\n [style.height.px]=\"this.nzWidth\"\n [style.fontSize.px]=\"this.nzWidth*0.15+6\"\n class=\"ant-progress-inner\"\n *ngIf=\"isCirCleStyle\">\n <svg class=\"ant-progress-circle \" viewBox=\"0 0 100 100\">\n <path\n class=\"ant-progress-circle-trail\"\n stroke=\"#f3f3f3\"\n fill-opacity=\"0\"\n [attr.stroke-width]=\"nzStrokeWidth\"\n [ngStyle]=\"trailPathStyle\"\n [attr.d]=\"pathString\">\n </path>\n <path\n class=\"ant-progress-circle-path\"\n [attr.d]=\"pathString\"\n [attr.stroke-linecap]=\"nzStrokeLinecap\"\n fill-opacity=\"0\"\n [attr.stroke]=\"nzStrokeColor || statusColorMap[nzStatus]\"\n [attr.stroke-width]=\"nzPercent?nzStrokeWidth:0\"\n [ngStyle]=\"strokePathStyle\">\n </path>\n </svg>\n <ng-template [ngTemplateOutlet]=\"progressInfoTemplate\"></ng-template>\n </div>\n</div>" }] } ]; NzProgressComponent.propDecorators = { nzShowInfo: [{ type: Input }], nzWidth: [{ type: Input }], nzSuccessPercent: [{ type: Input }], nzStrokeColor: [{ type: Input }], nzSize: [{ type: Input }], nzFormat: [{ type: Input }], nzPercent: [{ type: Input }], nzStrokeWidth: [{ type: Input }], nzStatus: [{ type: Input }], nzType: [{ type: Input }], nzGapDegree: [{ type: Input }], nzGapPosition: [{ type: Input }], nzStrokeLinecap: [{ type: Input }] }; if (false) { /** * @type {?} * @private */ NzProgressComponent.prototype._gapDegree; /** * @type {?} * @private */ NzProgressComponent.prototype._gapPosition; /** * @type {?} * @private */ NzProgressComponent.prototype._percent; /** * @type {?} * @private */ NzProgressComponent.prototype._status; /** * @type {?} * @private */ NzProgressComponent.prototype._cacheStatus; /** * @type {?} * @private */ NzProgressComponent.prototype._strokeLinecap; /** * @type {?} * @private */ NzProgressComponent.prototype._strokeWidth; /** * @type {?} * @private */ NzProgressComponent.prototype._size; /** * @type {?} * @private */ NzProgressComponent.prototype._type; /** * @type {?} * @private */ NzProgressComponent.prototype._format; /** @type {?} */ NzProgressComponent.prototype.trailPathStyle; /** @type {?} */ NzProgressComponent.prototype.strokePathStyle; /** @type {?} */ NzProgressComponent.prototype.pathString; /** @type {?} */ NzProgressComponent.prototype.icon; /** @type {?} */ NzProgressComponent.prototype.iconTheme; /** @type {?} */ NzProgressComponent.prototype.isStatusSet; /** @type {?} */ NzProgressComponent.prototype.isStrokeWidthSet; /** @type {?} */ NzProgressComponent.prototype.isFormatSet; /** @type {?} */ NzProgressComponent.prototype.isGapDegreeSet; /** @type {?} */ NzProgressComponent.prototype.isGapPositionSet; /** @type {?} */ NzProgressComponent.prototype.statusColorMap; /** @type {?} */ NzProgressComponent.prototype.nzShowInfo; /** @type {?} */ NzProgressComponent.prototype.nzWidth; /** @type {?} */ NzProgressComponent.prototype.nzSuccessPercent; /** @type {?} */ NzProgressComponent.prototype.nzStrokeColor; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-progress.component.js","sourceRoot":"ng://ng-zorro-antd/","sources":["progress/nz-progress.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EACT,KAAK,EAEN,MAAM,eAAe,CAAC;AAMvB,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAO9C,MAAM,OAAO,mBAAmB;IALhC;QAMU,eAAU,GAAG,CAAC,CAAC;QACf,iBAAY,GAA8B,KAAK,CAAC;QAChD,aAAQ,GAAG,CAAC,CAAC;QACb,YAAO,GAAyB,QAAQ,CAAC;QACzC,iBAAY,GAAyB,QAAQ,CAAC;QAC9C,mBAAc,GAAgC,OAAO,CAAC;QACtD,iBAAY,GAAG,CAAC,CAAC;QACjB,UAAK,GAAG,SAAS,CAAC;QAClB,UAAK,GAAuB,MAAM,CAAC;QACnC,YAAO;;;;QAAG,CAAC,OAAe,EAAU,EAAE,CAAC,GAAG,OAAO,GAAG,EAAC;QAM7D,gBAAW,GAAG,KAAK,CAAC;QACpB,qBAAgB,GAAG,KAAK,CAAC;QACzB,gBAAW,GAAG,KAAK,CAAC;QACpB,mBAAc,GAAG,KAAK,CAAC;QACvB,qBAAgB,GAAG,KAAK,CAAC;QACzB,mBAAc,GAAG;YACf,MAAM,EAAK,SAAS;YACpB,SAAS,EAAE,SAAS;YACpB,OAAO,EAAI,SAAS;SACrB,CAAC;QACO,eAAU,GAAG,IAAI,CAAC;QAClB,YAAO,GAAG,GAAG,CAAC;QACd,qBAAgB,GAAG,CAAC,CAAC;IA4MhC,CAAC;;;;;IAzMC,IACI,MAAM,CAAC,KAAa;QACtB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,IAAI,CAAC,MAAM,KAAK,OAAO,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YACrD,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;SACvB;IACH,CAAC;;;;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;;;;;IAED,IACI,QAAQ,CAAC,KAAkC;QAC7C,IAAI,QAAQ,CAAC,KAAK,CAAC,EAAE;YACnB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;SACzB;IACH,CAAC;;;;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;;;;;IAED,IACI,SAAS,CAAC,KAAa;QACzB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,QAAQ,CAAC,KAAK,CAAC,EAAE;;kBACb,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,QAAQ,EAAE,EAAE,EAAE,CAAC,IAAI,GAAG;YACrD,IAAI,OAAO,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;gBAChC,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;aAC1B;iBAAM;gBACL,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC;aAClC;YACD,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;;;;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;;;;;IAED,IACI,aAAa,CAAC,KAAa;QAC7B,IAAI,QAAQ,CAAC,KAAK,CAAC,EAAE;YACnB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;IACH,CAAC;;;;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;;;;;IAED,IACI,QAAQ,CAAC,KAA2B;QACtC,IAAI,QAAQ,CAAC,KAAK,CAAC,EAAE;YACnB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,UAAU,EAAE,CAAC;SACnB;IACH,CAAC;;;;IAED,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;;;;;IAED,IACI,MAAM,CAAC,KAAyB;QAClC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YAC1B,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,EAAE;gBAC1B,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;aACvB;SACF;QACD,IAAI,IAAI,CAAC,MAAM,KAAK,WAAW,EAAE;YAC/B,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;gBAC1B,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;aAC9B;YACD,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;gBACxB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;aACtB;SACF;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;;;;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;;;;;IAED,IACI,WAAW,CAAC,KAAa;QAC3B,IAAI,QAAQ,CAAC,KAAK,CAAC,EAAE;YACnB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;YAC3B,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;IAEH,CAAC;;;;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;;;;;IAED,IACI,aAAa,CAAC,KAAgC;QAChD,IAAI,QAAQ,CAAC,KAAK,CAAC,EAAE;YACnB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;IACH,CAAC;;;;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;;;;;IAED,IACI,eAAe,CAAC,KAAkC;QACpD,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;;;;IAED,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;;;;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,MAAM,KAAK,QAAQ,IAAI,IAAI,CAAC,MAAM,KAAK,WAAW,CAAC;IACjE,CAAC;;;;IAED,gBAAgB;;cACR,MAAM,GAAG,EAAE,GAAG,CAAC,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;;YACxC,cAAc,GAAG,CAAC;;YAClB,cAAc,GAAG,CAAC,MAAM;;YACxB,YAAY,GAAG,CAAC;;YAChB,YAAY,GAAG,MAAM,GAAG,CAAC,CAAC;QAC9B,QAAQ,IAAI,CAAC,aAAa,EAAE;YAC1B,KAAK,MAAM;gBACT,cAAc,GAAG,CAAC,MAAM,CAAC;gBACzB,cAAc,GAAG,CAAC,CAAC;gBACnB,YAAY,GAAG,MAAM,GAAG,CAAC,CAAC;gBAC1B,YAAY,GAAG,CAAC,CAAC;gBACjB,MAAM;YACR,KAAK,OAAO;gBACV,cAAc,GAAG,MAAM,CAAC;gBACxB,cAAc,GAAG,CAAC,CAAC;gBACnB,YAAY,GAAG,MAAM,GAAG,CAAC,CAAC,CAAC;gBAC3B,YAAY,GAAG,CAAC,CAAC;gBACjB,MAAM;YACR,KAAK,QAAQ;gBACX,cAAc,GAAG,MAAM,CAAC;gBACxB,YAAY,GAAG,MAAM,GAAG,CAAC,CAAC;gBAC1B,MAAM;YACR,QAAQ;SACT;QACD,IAAI,CAAC,UAAU,GAAG,aAAa,cAAc,IAAI,cAAc;SAC1D,MAAM,IAAI,MAAM,UAAU,YAAY,IAAI,CAAC,YAAY;SACvD,MAAM,IAAI,MAAM,UAAU,CAAC,YAAY,IAAI,YAAY,EAAE,CAAC;;cACzD,GAAG,GAAG,IAAI,CAAC,EAAE,GAAG,CAAC,GAAG,MAAM;QAChC,IAAI,CAAC,cAAc,GAAG;YACpB,eAAe,EAAG,GAAG,GAAG,GAAG,IAAI,CAAC,WAAW,MAAM,GAAG,IAAI;YACxD,gBAAgB,EAAE,IAAI,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI;YAC9C,UAAU,EAAQ,yEAAyE;SAC5F,CAAC;QACF,IAAI,CAAC,eAAe,GAAG;YACrB,eAAe,EAAG,GAAG,CAAC,IAAI,CAAC,SAAS,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,IAAI;YACnF,gBAAgB,EAAE,IAAI,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI;YAC9C,UAAU,EAAQ,qGAAqG,CAAC,sBAAsB;SAC/I,CAAC;IACJ,CAAC;;;;IAED,UAAU;;cACF,QAAQ,GAAG,CAAC,IAAI,CAAC,MAAM,KAAK,QAAQ,IAAI,IAAI,CAAC,MAAM,KAAK,WAAW,CAAC;;YACtE,GAAG,GAAG,EAAE;QACZ,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;YAC/B,GAAG,GAAG,OAAO,CAAC;SACf;QACD,IAAI,IAAI,CAAC,QAAQ,KAAK,WAAW,EAAE;YACjC,GAAG,GAAG,OAAO,CAAC;SACf;QACD,IAAI,GAAG,EAAE;YACP,IAAI,CAAC,QAAQ,EAAE;gBACb,GAAG,IAAI,SAAS,CAAC;gBACjB,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;aACzB;iBAAM;gBACL,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;aAC5B;SACF;QACD,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC;IAClB,CAAC;;;;IAED,QAAQ;QACN,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;;;YA3OF,SAAS,SAAC;gBACT,QAAQ,EAAa,aAAa;gBAClC,mBAAmB,EAAE,KAAK;gBAC1B,i4EAAmD;aACpD;;;yBA2BE,KAAK;sBACL,KAAK;+BACL,KAAK;4BACL,KAAK;qBAEL,KAAK;uBAYL,KAAK;wBAYL,KAAK;4BAmBL,KAAK;uBAaL,KAAK;qBAcL,KAAK;0BAwBL,KAAK;4BAcL,KAAK;8BAaL,KAAK;;;;;;;IAvJN,yCAAuB;;;;;IACvB,2CAAwD;;;;;IACxD,uCAAqB;;;;;IACrB,sCAAiD;;;;;IACjD,2CAAsD;;;;;IACtD,6CAA8D;;;;;IAC9D,2CAAyB;;;;;IACzB,oCAA0B;;;;;IAC1B,oCAA2C;;;;;IAC3C,sCAA6D;;IAC7D,6CAA4C;;IAC5C,8CAA6C;;IAC7C,yCAAmB;;IACnB,mCAAK;;IACL,wCAAU;;IACV,0CAAoB;;IACpB,+CAAyB;;IACzB,0CAAoB;;IACpB,6CAAuB;;IACvB,+CAAyB;;IACzB,6CAIE;;IACF,yCAA2B;;IAC3B,sCAAuB;;IACvB,+CAA8B;;IAC9B,4CAA+B","sourcesContent":["import {\n  Component,\n  Input,\n  OnInit\n} from '@angular/core';\n\nexport type NzProgressGapPositionType = 'top' | 'bottom' | 'left' | 'right';\nexport type NzProgressStatusType = 'success' | 'exception' | 'active' | 'normal';\nexport type NzProgressTypeType = 'line' | 'circle' | 'dashboard';\nexport type NzProgressStrokeLinecapType = 'round' | 'square';\nimport { isNotNil } from '../core/util/check';\n\n@Component({\n  selector           : 'nz-progress',\n  preserveWhitespaces: false,\n  templateUrl        : './nz-progress.component.html'\n})\nexport class NzProgressComponent implements OnInit {\n  private _gapDegree = 0;\n  private _gapPosition: NzProgressGapPositionType = 'top';\n  private _percent = 0;\n  private _status: NzProgressStatusType = 'normal';\n  private _cacheStatus: NzProgressStatusType = 'normal';\n  private _strokeLinecap: NzProgressStrokeLinecapType = 'round';\n  private _strokeWidth = 8;\n  private _size = 'default';\n  private _type: NzProgressTypeType = 'line';\n  private _format = (percent: number): string => `${percent}%`;\n  trailPathStyle: { [ key: string ]: string };\n  strokePathStyle: { [ key: string ]: string };\n  pathString: string;\n  icon;\n  iconTheme;\n  isStatusSet = false;\n  isStrokeWidthSet = false;\n  isFormatSet = false;\n  isGapDegreeSet = false;\n  isGapPositionSet = false;\n  statusColorMap = {\n    normal   : '#108ee9',\n    exception: '#ff5500',\n    success  : '#87d068'\n  };\n  @Input() nzShowInfo = true;\n  @Input() nzWidth = 132;\n  @Input() nzSuccessPercent = 0;\n  @Input() nzStrokeColor: string;\n\n  @Input()\n  set nzSize(value: string) {\n    this._size = value;\n    if (this.nzSize === 'small' && !this.isStrokeWidthSet) {\n      this._strokeWidth = 6;\n    }\n  }\n\n  get nzSize(): string {\n    return this._size;\n  }\n\n  @Input()\n  set nzFormat(value: (percent: number) => string) {\n    if (isNotNil(value)) {\n      this._format = value;\n      this.isFormatSet = true;\n    }\n  }\n\n  get nzFormat(): (percent: number) => string {\n    return this._format;\n  }\n\n  @Input()\n  set nzPercent(value: number) {\n    this._percent = value;\n    if (isNotNil(value)) {\n      const fillAll = parseInt(value.toString(), 10) >= 100;\n      if (fillAll && !this.isStatusSet) {\n        this._status = 'success';\n      } else {\n        this._status = this._cacheStatus;\n      }\n      this.updatePathStyles();\n      this.updateIcon();\n    }\n  }\n\n  get nzPercent(): number {\n    return this._percent;\n  }\n\n  @Input()\n  set nzStrokeWidth(value: number) {\n    if (isNotNil(value)) {\n      this._strokeWidth = value;\n      this.isStrokeWidthSet = true;\n      this.updatePathStyles();\n    }\n  }\n\n  get nzStrokeWidth(): number {\n    return this._strokeWidth;\n  }\n\n  @Input()\n  set nzStatus(value: NzProgressStatusType) {\n    if (isNotNil(value)) {\n      this._status = value;\n      this._cacheStatus = value;\n      this.isStatusSet = true;\n      this.updateIcon();\n    }\n  }\n\n  get nzStatus(): NzProgressStatusType {\n    return this._status;\n  }\n\n  @Input()\n  set nzType(value: NzProgressTypeType) {\n    this._type = value;\n    if (!this.isStrokeWidthSet) {\n      if (this.nzType !== 'line') {\n        this._strokeWidth = 6;\n      }\n    }\n    if (this.nzType === 'dashboard') {\n      if (!this.isGapPositionSet) {\n        this._gapPosition = 'bottom';\n      }\n      if (!this.isGapDegreeSet) {\n        this._gapDegree = 75;\n      }\n    }\n    this.updateIcon();\n    this.updatePathStyles();\n  }\n\n  get nzType(): NzProgressTypeType {\n    return this._type;\n  }\n\n  @Input()\n  set nzGapDegree(value: number) {\n    if (isNotNil(value)) {\n      this._gapDegree = value;\n      this.isGapDegreeSet = true;\n      this.updatePathStyles();\n    }\n\n  }\n\n  get nzGapDegree(): number {\n    return this._gapDegree;\n  }\n\n  @Input()\n  set nzGapPosition(value: NzProgressGapPositionType) {\n    if (isNotNil(value)) {\n      this._gapPosition = value;\n      this.isGapPositionSet = true;\n      this.updatePathStyles();\n    }\n  }\n\n  get nzGapPosition(): NzProgressGapPositionType {\n    return this._gapPosition;\n  }\n\n  @Input()\n  set nzStrokeLinecap(value: NzProgressStrokeLinecapType) {\n    this._strokeLinecap = value;\n    this.updatePathStyles();\n  }\n\n  get nzStrokeLinecap(): NzProgressStrokeLinecapType {\n    return this._strokeLinecap;\n  }\n\n  get isCirCleStyle(): boolean {\n    return this.nzType === 'circle' || this.nzType === 'dashboard';\n  }\n\n  updatePathStyles(): void {\n    const radius = 50 - (this.nzStrokeWidth / 2);\n    let beginPositionX = 0;\n    let beginPositionY = -radius;\n    let endPositionX = 0;\n    let endPositionY = radius * -2;\n    switch (this.nzGapPosition) {\n      case 'left':\n        beginPositionX = -radius;\n        beginPositionY = 0;\n        endPositionX = radius * 2;\n        endPositionY = 0;\n        break;\n      case 'right':\n        beginPositionX = radius;\n        beginPositionY = 0;\n        endPositionX = radius * -2;\n        endPositionY = 0;\n        break;\n      case 'bottom':\n        beginPositionY = radius;\n        endPositionY = radius * 2;\n        break;\n      default:\n    }\n    this.pathString = `M 50,50 m ${beginPositionX},${beginPositionY}\n     a ${radius},${radius} 0 1 1 ${endPositionX},${-endPositionY}\n     a ${radius},${radius} 0 1 1 ${-endPositionX},${endPositionY}`;\n    const len = Math.PI * 2 * radius;\n    this.trailPathStyle = {\n      strokeDasharray : `${len - this.nzGapDegree}px ${len}px`,\n      strokeDashoffset: `-${this.nzGapDegree / 2}px`,\n      transition      : 'stroke-dashoffset .3s ease 0s, stroke-dasharray .3s ease 0s, stroke .3s'\n    };\n    this.strokePathStyle = {\n      strokeDasharray : `${(this.nzPercent / 100) * (len - this.nzGapDegree)}px ${len}px`,\n      strokeDashoffset: `-${this.nzGapDegree / 2}px`,\n      transition      : 'stroke-dashoffset .3s ease 0s, stroke-dasharray .3s ease 0s, stroke .3s, stroke-width .06s ease .3s' // eslint-disable-line\n    };\n  }\n\n  updateIcon(): void {\n    const isCircle = (this.nzType === 'circle' || this.nzType === 'dashboard');\n    let ret = '';\n    if (this.nzStatus === 'success') {\n      ret = 'check';\n    }\n    if (this.nzStatus === 'exception') {\n      ret = 'close';\n    }\n    if (ret) {\n      if (!isCircle) {\n        ret += '-circle';\n        this.iconTheme = 'fill';\n      } else {\n        this.iconTheme = 'outline';\n      }\n    }\n    this.icon = ret;\n  }\n\n  ngOnInit(): void {\n    this.updatePathStyles();\n    this.updateIcon();\n  }\n\n}\n"]}