ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
256 lines • 18.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, ContentChildren, QueryList, HostBinding, Renderer2, ElementRef } from '@angular/core';
import { StepStatusEnum, StepDirectionEnum } from './step/step.component';
import { StepComponent } from './step/step.component';
var StepsComponent = /** @class */ (function () {
function StepsComponent(_elf, _render) {
this._elf = _elf;
this._render = _render;
this.prefixCls = 'am-steps';
this._current = 0;
this._status = StepStatusEnum.PROCESS;
this._direction = StepDirectionEnum.VERTICAL;
this.clsSteps = true;
}
Object.defineProperty(StepsComponent.prototype, "current", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
if (value >= 0) {
this._current = value;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(StepsComponent.prototype, "size", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._size = value;
this.setCls();
},
enumerable: true,
configurable: true
});
Object.defineProperty(StepsComponent.prototype, "status", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._status = value;
if (this.stepItems) {
this.setStepStyle();
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(StepsComponent.prototype, "direction", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._direction = value;
this.setCls();
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
StepsComponent.prototype.setStepStyle = /**
* @return {?}
*/
function () {
/** @type {?} */
var itemCount = this.stepItems.length;
/** @type {?} */
var itemArr = this.stepItems['_results'];
for (var index = 0; index < itemCount; index++) {
/** @type {?} */
var step = itemArr[index];
step.stepNumber = index + 1;
if (index < itemCount - 1 && itemArr[index + 1].status === StepStatusEnum.ERROR) {
step.stepItemCls = step.stepItemCls
? Object.assign(step.stepItemCls, { 'error-tail': true })
: { 'error-tail': true };
}
/** @type {?} */
var icon = step.icon;
if (!step.status) {
if (index === this._current) {
step.status = this._status;
}
else if (index < this._current) {
step.status = StepStatusEnum.FINISH;
}
else {
step.status = StepStatusEnum.WAIT;
}
}
else if (step.status && !icon) {
switch (step.status) {
case StepStatusEnum.FINISH:
icon = 'check-circle-o';
break;
case StepStatusEnum.ERROR:
icon = 'cross-circle-o';
break;
}
}
if (!icon && step.status !== StepStatusEnum.PROCESS) {
if (index < this._current) {
icon = 'check-circle-o';
}
else if (index > this._current) {
icon = 'ellipsis';
step.stepItemCls = step.stepItemCls
? Object.assign(step.stepItemCls, { 'ellipsis-item': true })
: { 'ellipsis-item': true };
}
if ((this._status === StepStatusEnum.ERROR && index === this._current) ||
step.status === StepStatusEnum.ERROR) {
icon = 'cross-circle-o';
}
}
step.icon = icon;
step.iconSize = this._size === 'small' ? (this._status === StepStatusEnum.WAIT ? 'xxs' : 'xs') : 'md';
step.setClass();
}
};
/**
* @return {?}
*/
StepsComponent.prototype.setCls = /**
* @return {?}
*/
function () {
if (this._direction === StepDirectionEnum.HORIZONTAL) {
this.clsStepsLabelVtl = true;
this.clsStepsHztl = true;
this.clsStepsVtl = false;
}
else if (this._direction === StepDirectionEnum.VERTICAL) {
this.clsStepsVtl = true;
this.clsStepsHztl = false;
}
if (this._size === 'small') {
this.clsStepsSmall = true;
}
else {
this.clsStepsSmall = false;
}
};
/**
* @return {?}
*/
StepsComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.setCls();
};
/**
* @return {?}
*/
StepsComponent.prototype.ngAfterContentInit = /**
* @return {?}
*/
function () {
var _this = this;
setTimeout((/**
* @return {?}
*/
function () {
_this.setStepStyle();
}), 0);
};
StepsComponent.decorators = [
{ type: Component, args: [{
selector: 'Steps,nzm-steps',
template: "<ng-content></ng-content>\n"
}] }
];
/** @nocollapse */
StepsComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: Renderer2 }
]; };
StepsComponent.propDecorators = {
stepItems: [{ type: ContentChildren, args: [StepComponent,] }],
current: [{ type: Input }],
size: [{ type: Input }],
status: [{ type: Input }],
direction: [{ type: Input }],
clsSteps: [{ type: HostBinding, args: ['class.am-steps',] }],
clsStepsSmall: [{ type: HostBinding, args: ['class.am-steps-small',] }],
clsStepsLabelVtl: [{ type: HostBinding, args: ['class.am-steps-label-vertical',] }],
clsStepsVtl: [{ type: HostBinding, args: ['class.am-steps-vertical',] }],
clsStepsHztl: [{ type: HostBinding, args: ['class.am-steps-horizontal',] }]
};
return StepsComponent;
}());
export { StepsComponent };
if (false) {
/** @type {?} */
StepsComponent.prototype.prefixCls;
/**
* @type {?}
* @private
*/
StepsComponent.prototype._current;
/**
* @type {?}
* @private
*/
StepsComponent.prototype._size;
/**
* @type {?}
* @private
*/
StepsComponent.prototype._status;
/**
* @type {?}
* @private
*/
StepsComponent.prototype._direction;
/**
* @type {?}
* @private
*/
StepsComponent.prototype._stepsCls;
/** @type {?} */
StepsComponent.prototype.stepItems;
/** @type {?} */
StepsComponent.prototype.clsSteps;
/** @type {?} */
StepsComponent.prototype.clsStepsSmall;
/** @type {?} */
StepsComponent.prototype.clsStepsLabelVtl;
/** @type {?} */
StepsComponent.prototype.clsStepsVtl;
/** @type {?} */
StepsComponent.prototype.clsStepsHztl;
/**
* @type {?}
* @private
*/
StepsComponent.prototype._elf;
/**
* @type {?}
* @private
*/
StepsComponent.prototype._render;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"steps.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["steps/steps.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EAET,KAAK,EACL,eAAe,EACf,SAAS,EAET,WAAW,EACX,SAAS,EACT,UAAU,EACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAC1E,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAEtD;IAmDE,wBAAoB,IAAgB,EAAU,OAAkB;QAA5C,SAAI,GAAJ,IAAI,CAAY;QAAU,YAAO,GAAP,OAAO,CAAW;QA9ChE,cAAS,GAAW,UAAU,CAAC;QAEvB,aAAQ,GAAW,CAAC,CAAC;QAErB,YAAO,GAAmB,cAAc,CAAC,OAAO,CAAC;QACjD,eAAU,GAAsB,iBAAiB,CAAC,QAAQ,CAAC;QA+BnE,aAAQ,GAAY,IAAI,CAAC;IAU2C,CAAC;IAnCrE,sBACI,mCAAO;;;;;QADX,UACY,KAAK;YACf,IAAI,KAAK,IAAI,CAAC,EAAE;gBACd,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;aACvB;QACH,CAAC;;;OAAA;IACD,sBACI,gCAAI;;;;;QADR,UACS,KAAK;YACZ,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,CAAC;;;OAAA;IACD,sBACI,kCAAM;;;;;QADV,UACW,KAAqB;YAC9B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,YAAY,EAAE,CAAC;aACrB;QACH,CAAC;;;OAAA;IACD,sBACI,qCAAS;;;;;QADb,UACc,KAAwB;YACpC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,MAAM,EAAE,CAAC;QAChB,CAAC;;;OAAA;;;;IAeD,qCAAY;;;IAAZ;;YACQ,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM;;YACjC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;QAC1C,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,SAAS,EAAE,KAAK,EAAE,EAAE;;gBACxC,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC;YAC3B,IAAI,CAAC,UAAU,GAAG,KAAK,GAAG,CAAC,CAAC;YAC5B,IAAI,KAAK,GAAG,SAAS,GAAG,CAAC,IAAI,OAAO,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,MAAM,KAAK,cAAc,CAAC,KAAK,EAAE;gBAC/E,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW;oBACjC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC;oBACzD,CAAC,CAAC,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC;aAC5B;;gBACG,IAAI,GAAG,IAAI,CAAC,IAAI;YACpB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;gBAChB,IAAI,KAAK,KAAK,IAAI,CAAC,QAAQ,EAAE;oBAC3B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;iBAC5B;qBAAM,IAAI,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE;oBAChC,IAAI,CAAC,MAAM,GAAG,cAAc,CAAC,MAAM,CAAC;iBACrC;qBAAM;oBACL,IAAI,CAAC,MAAM,GAAG,cAAc,CAAC,IAAI,CAAC;iBACnC;aACF;iBAAM,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,EAAE;gBAC/B,QAAQ,IAAI,CAAC,MAAM,EAAE;oBACnB,KAAM,cAAc,CAAC,MAAM;wBACzB,IAAI,GAAG,gBAAgB,CAAC;wBACxB,MAAM;oBACR,KAAK,cAAc,CAAC,KAAK;wBACvB,IAAI,GAAG,gBAAgB,CAAC;wBACxB,MAAM;iBACT;aACF;YACD,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,KAAK,cAAc,CAAC,OAAO,EAAE;gBACnD,IAAI,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE;oBACzB,IAAI,GAAG,gBAAgB,CAAC;iBACzB;qBAAM,IAAI,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE;oBAChC,IAAI,GAAG,UAAU,CAAC;oBAClB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW;wBACjC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC;wBAC5D,CAAC,CAAC,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC;iBAC/B;gBACD,IACE,CAAC,IAAI,CAAC,OAAO,KAAK,cAAc,CAAC,KAAK,IAAI,KAAK,KAAK,IAAI,CAAC,QAAQ,CAAC;oBAClE,IAAI,CAAC,MAAM,KAAK,cAAc,CAAC,KAAK,EACpC;oBACA,IAAI,GAAG,gBAAgB,CAAC;iBACzB;aACF;YACD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,KAAK,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YACtG,IAAI,CAAC,QAAQ,EAAE,CAAC;SACjB;IACH,CAAC;;;;IAED,+BAAM;;;IAAN;QACE,IAAI,IAAI,CAAC,UAAU,KAAK,iBAAiB,CAAC,UAAU,EAAE;YACpD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;SAC1B;aAAM,IAAI,IAAI,CAAC,UAAU,KAAK,iBAAiB,CAAC,QAAQ,EAAE;YACzD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;SAC3B;QACD,IAAI,IAAI,CAAC,KAAK,KAAK,OAAO,EAAE;YAC1B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;aAAM;YACL,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;SAC5B;IACH,CAAC;;;;IAED,iCAAQ;;;IAAR;QACE,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;;;;IAED,2CAAkB;;;IAAlB;QAAA,iBAIC;QAHC,UAAU;;;QAAC;YACT,KAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,GAAE,CAAC,CAAC,CAAC;IACR,CAAC;;gBAjIF,SAAS,SAAC;oBACT,QAAQ,EAAE,iBAAiB;oBAC3B,uCAAqC;iBACtC;;;;gBARC,UAAU;gBADV,SAAS;;;4BAmBR,eAAe,SAAC,aAAa;0BAG7B,KAAK;uBAML,KAAK;yBAKL,KAAK;4BAOL,KAAK;2BAML,WAAW,SAAC,gBAAgB;gCAE5B,WAAW,SAAC,sBAAsB;mCAElC,WAAW,SAAC,+BAA+B;8BAE3C,WAAW,SAAC,yBAAyB;+BAErC,WAAW,SAAC,2BAA2B;;IAkF1C,qBAAC;CAAA,AAlID,IAkIC;SA9HY,cAAc;;;IACzB,mCAA+B;;;;;IAE/B,kCAA6B;;;;;IAC7B,+BAAsB;;;;;IACtB,iCAAyD;;;;;IACzD,oCAAmE;;;;;IACnE,mCAA0B;;IAE1B,mCACoC;;IA0BpC,kCACyB;;IACzB,uCACuB;;IACvB,0CAC0B;;IAC1B,qCACqB;;IACrB,sCACsB;;;;;IAEV,8BAAwB;;;;;IAAE,iCAA0B","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  ContentChildren,\n  QueryList,\n  AfterContentInit,\n  HostBinding,\n  Renderer2,\n  ElementRef\n} from '@angular/core';\nimport { StepStatusEnum, StepDirectionEnum } from './step/step.component';\nimport { StepComponent } from './step/step.component';\n\n@Component({\n  selector: 'Steps,nzm-steps',\n  templateUrl: './steps.component.html'\n})\nexport class StepsComponent implements OnInit, AfterContentInit {\n  prefixCls: string = 'am-steps';\n\n  private _current: number = 0;\n  private _size: string;\n  private _status: StepStatusEnum = StepStatusEnum.PROCESS;\n  private _direction: StepDirectionEnum = StepDirectionEnum.VERTICAL;\n  private _stepsCls: object;\n\n  @ContentChildren(StepComponent)\n  stepItems: QueryList<StepComponent>;\n\n  @Input()\n  set current(value) {\n    if (value >= 0) {\n      this._current = value;\n    }\n  }\n  @Input()\n  set size(value) {\n    this._size = value;\n    this.setCls();\n  }\n  @Input()\n  set status(value: StepStatusEnum) {\n    this._status = value;\n    if (this.stepItems) {\n      this.setStepStyle();\n    }\n  }\n  @Input()\n  set direction(value: StepDirectionEnum) {\n    this._direction = value;\n    this.setCls();\n  }\n\n  @HostBinding('class.am-steps')\n  clsSteps: boolean = true;\n  @HostBinding('class.am-steps-small')\n  clsStepsSmall: boolean;\n  @HostBinding('class.am-steps-label-vertical')\n  clsStepsLabelVtl: boolean;\n  @HostBinding('class.am-steps-vertical')\n  clsStepsVtl: boolean;\n  @HostBinding('class.am-steps-horizontal')\n  clsStepsHztl: boolean;\n\n  constructor(private _elf: ElementRef, private _render: Renderer2) { }\n\n  setStepStyle() {\n    const itemCount = this.stepItems.length;\n    const itemArr = this.stepItems['_results'];\n    for (let index = 0; index < itemCount; index++) {\n      const step = itemArr[index];\n      step.stepNumber = index + 1;\n      if (index < itemCount - 1 && itemArr[index + 1].status === StepStatusEnum.ERROR) {\n        step.stepItemCls = step.stepItemCls\n          ? Object.assign(step.stepItemCls, { 'error-tail': true })\n          : { 'error-tail': true };\n      }\n      let icon = step.icon;\n      if (!step.status) {\n        if (index === this._current) {\n          step.status = this._status;\n        } else if (index < this._current) {\n          step.status = StepStatusEnum.FINISH;\n        } else {\n          step.status = StepStatusEnum.WAIT;\n        }\n      } else if (step.status && !icon) {\n        switch (step.status) {\n          case  StepStatusEnum.FINISH:\n            icon = 'check-circle-o';\n            break;\n          case StepStatusEnum.ERROR:\n            icon = 'cross-circle-o';\n            break;\n        }\n      }\n      if (!icon && step.status !== StepStatusEnum.PROCESS) {\n        if (index < this._current) {\n          icon = 'check-circle-o';\n        } else if (index > this._current) {\n          icon = 'ellipsis';\n          step.stepItemCls = step.stepItemCls\n            ? Object.assign(step.stepItemCls, { 'ellipsis-item': true })\n            : { 'ellipsis-item': true };\n        }\n        if (\n          (this._status === StepStatusEnum.ERROR && index === this._current) ||\n          step.status === StepStatusEnum.ERROR\n        ) {\n          icon = 'cross-circle-o';\n        }\n      }\n      step.icon = icon;\n      step.iconSize = this._size === 'small' ? (this._status === StepStatusEnum.WAIT ? 'xxs' : 'xs') : 'md';\n      step.setClass();\n    }\n  }\n\n  setCls() {\n    if (this._direction === StepDirectionEnum.HORIZONTAL) {\n      this.clsStepsLabelVtl = true;\n      this.clsStepsHztl = true;\n      this.clsStepsVtl = false;\n    } else if (this._direction === StepDirectionEnum.VERTICAL) {\n      this.clsStepsVtl = true;\n      this.clsStepsHztl = false;\n    }\n    if (this._size === 'small') {\n      this.clsStepsSmall = true;\n    } else {\n      this.clsStepsSmall = false;\n    }\n  }\n\n  ngOnInit() {\n    this.setCls();\n  }\n\n  ngAfterContentInit() {\n    setTimeout(() => {\n      this.setStepStyle();\n    }, 0);\n  }\n}\n"]}