ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
397 lines • 29.6 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';
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":"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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"]}