UNPKG

ng-zorro-antd

Version:

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

446 lines 32.3 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'; var NzProgressComponent = /** @class */ (function () { function NzProgressComponent() { 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 {?} */ function (percent) { return 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; } Object.defineProperty(NzProgressComponent.prototype, "nzSize", { get: /** * @return {?} */ function () { return this._size; }, set: /** * @param {?} value * @return {?} */ function (value) { this._size = value; if (this.nzSize === 'small' && !this.isStrokeWidthSet) { this._strokeWidth = 6; } }, enumerable: true, configurable: true }); Object.defineProperty(NzProgressComponent.prototype, "nzFormat", { get: /** * @return {?} */ function () { return this._format; }, set: /** * @param {?} value * @return {?} */ function (value) { if (isNotNil(value)) { this._format = value; this.isFormatSet = true; } }, enumerable: true, configurable: true }); Object.defineProperty(NzProgressComponent.prototype, "nzPercent", { get: /** * @return {?} */ function () { return this._percent; }, set: /** * @param {?} value * @return {?} */ function (value) { this._percent = value; if (isNotNil(value)) { /** @type {?} */ var fillAll = parseInt(value.toString(), 10) >= 100; if (fillAll && !this.isStatusSet) { this._status = 'success'; } else { this._status = this._cacheStatus; } this.updatePathStyles(); this.updateIcon(); } }, enumerable: true, configurable: true }); Object.defineProperty(NzProgressComponent.prototype, "nzStrokeWidth", { get: /** * @return {?} */ function () { return this._strokeWidth; }, set: /** * @param {?} value * @return {?} */ function (value) { if (isNotNil(value)) { this._strokeWidth = value; this.isStrokeWidthSet = true; this.updatePathStyles(); } }, enumerable: true, configurable: true }); Object.defineProperty(NzProgressComponent.prototype, "nzStatus", { get: /** * @return {?} */ function () { return this._status; }, set: /** * @param {?} value * @return {?} */ function (value) { if (isNotNil(value)) { this._status = value; this._cacheStatus = value; this.isStatusSet = true; this.updateIcon(); } }, enumerable: true, configurable: true }); Object.defineProperty(NzProgressComponent.prototype, "nzType", { get: /** * @return {?} */ function () { return this._type; }, set: /** * @param {?} value * @return {?} */ function (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(); }, enumerable: true, configurable: true }); Object.defineProperty(NzProgressComponent.prototype, "nzGapDegree", { get: /** * @return {?} */ function () { return this._gapDegree; }, set: /** * @param {?} value * @return {?} */ function (value) { if (isNotNil(value)) { this._gapDegree = value; this.isGapDegreeSet = true; this.updatePathStyles(); } }, enumerable: true, configurable: true }); Object.defineProperty(NzProgressComponent.prototype, "nzGapPosition", { get: /** * @return {?} */ function () { return this._gapPosition; }, set: /** * @param {?} value * @return {?} */ function (value) { if (isNotNil(value)) { this._gapPosition = value; this.isGapPositionSet = true; this.updatePathStyles(); } }, enumerable: true, configurable: true }); Object.defineProperty(NzProgressComponent.prototype, "nzStrokeLinecap", { get: /** * @return {?} */ function () { return this._strokeLinecap; }, set: /** * @param {?} value * @return {?} */ function (value) { this._strokeLinecap = value; this.updatePathStyles(); }, enumerable: true, configurable: true }); Object.defineProperty(NzProgressComponent.prototype, "isCirCleStyle", { get: /** * @return {?} */ function () { return this.nzType === 'circle' || this.nzType === 'dashboard'; }, enumerable: true, configurable: true }); /** * @return {?} */ NzProgressComponent.prototype.updatePathStyles = /** * @return {?} */ function () { /** @type {?} */ var radius = 50 - (this.nzStrokeWidth / 2); /** @type {?} */ var beginPositionX = 0; /** @type {?} */ var beginPositionY = -radius; /** @type {?} */ var endPositionX = 0; /** @type {?} */ var 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 + "\n a " + radius + "," + radius + " 0 1 1 " + endPositionX + "," + -endPositionY + "\n a " + radius + "," + radius + " 0 1 1 " + -endPositionX + "," + endPositionY; /** @type {?} */ var 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 {?} */ NzProgressComponent.prototype.updateIcon = /** * @return {?} */ function () { /** @type {?} */ var isCircle = (this.nzType === 'circle' || this.nzType === 'dashboard'); /** @type {?} */ var 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 {?} */ NzProgressComponent.prototype.ngOnInit = /** * @return {?} */ function () { 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 }] }; return NzProgressComponent; }()); export { NzProgressComponent }; 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":"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","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"]}