ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
229 lines • 17.7 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';
export class StepsComponent {
/**
* @param {?} _elf
* @param {?} _render
*/
constructor(_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;
}
/**
* @param {?} value
* @return {?}
*/
set current(value) {
if (value >= 0) {
this._current = value;
}
}
/**
* @param {?} value
* @return {?}
*/
set size(value) {
this._size = value;
this.setCls();
}
/**
* @param {?} value
* @return {?}
*/
set status(value) {
this._status = value;
if (this.stepItems) {
this.setStepStyle();
}
}
/**
* @param {?} value
* @return {?}
*/
set direction(value) {
this._direction = value;
this.setCls();
}
/**
* @return {?}
*/
setStepStyle() {
/** @type {?} */
const itemCount = this.stepItems.length;
/** @type {?} */
const itemArr = this.stepItems['_results'];
for (let index = 0; index < itemCount; index++) {
/** @type {?} */
const 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 {?} */
let 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 {?}
*/
setCls() {
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 {?}
*/
ngOnInit() {
this.setCls();
}
/**
* @return {?}
*/
ngAfterContentInit() {
setTimeout((/**
* @return {?}
*/
() => {
this.setStepStyle();
}), 0);
}
}
StepsComponent.decorators = [
{ type: Component, args: [{
selector: 'Steps,nzm-steps',
template: "<ng-content></ng-content>\n"
}] }
];
/** @nocollapse */
StepsComponent.ctorParameters = () => [
{ 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',] }]
};
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;AAMtD,MAAM,OAAO,cAAc;;;;;IA+CzB,YAAoB,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,IACI,OAAO,CAAC,KAAK;QACf,IAAI,KAAK,IAAI,CAAC,EAAE;YACd,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;SACvB;IACH,CAAC;;;;;IACD,IACI,IAAI,CAAC,KAAK;QACZ,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;;;;;IACD,IACI,MAAM,CAAC,KAAqB;QAC9B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;;;;;IACD,IACI,SAAS,CAAC,KAAwB;QACpC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;;;;IAeD,YAAY;;cACJ,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM;;cACjC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;QAC1C,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,SAAS,EAAE,KAAK,EAAE,EAAE;;kBACxC,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,MAAM;QACJ,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,QAAQ;QACN,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;;;;IAED,kBAAkB;QAChB,UAAU;;;QAAC,GAAG,EAAE;YACd,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,GAAE,CAAC,CAAC,CAAC;IACR,CAAC;;;YAjIF,SAAS,SAAC;gBACT,QAAQ,EAAE,iBAAiB;gBAC3B,uCAAqC;aACtC;;;;YARC,UAAU;YADV,SAAS;;;wBAmBR,eAAe,SAAC,aAAa;sBAG7B,KAAK;mBAML,KAAK;qBAKL,KAAK;wBAOL,KAAK;uBAML,WAAW,SAAC,gBAAgB;4BAE5B,WAAW,SAAC,sBAAsB;+BAElC,WAAW,SAAC,+BAA+B;0BAE3C,WAAW,SAAC,yBAAyB;2BAErC,WAAW,SAAC,2BAA2B;;;;IA3CxC,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"]}