ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
446 lines • 32.3 kB
JavaScript
/**
* @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"]}