UNPKG

ng-zorro-antd-mobile

Version:

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

116 lines 13.4 kB
import { Component, Input, ContentChildren, QueryList, HostBinding, Renderer2, ElementRef } from '@angular/core'; import { StepStatusEnum, StepDirectionEnum } from './step/step.component'; import { StepComponent } from './step/step.component'; import * as i0 from "@angular/core"; export class StepsComponent { set current(value) { if (value >= 0) { this._current = value; if (this.stepItems) { this.setStepStyle(); } } } set size(value) { this._size = value; this.setCls(); } set status(value) { this._status = value; if (this.stepItems) { this.setStepStyle(); } } set direction(value) { this._direction = value; this.setCls(); } 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; } setStepStyle() { const itemCount = this.stepItems.length; const itemArr = this.stepItems['_results']; for (let index = 0; index < itemCount; index++) { const step = itemArr[index]; step.stepNumber = index + 1; step.outStatus = this._status; step.currentIndex = this._current + 1; step.iconSize = this._size === 'small' ? (this._status === StepStatusEnum.WAIT ? 'xxs' : 'xs') : 'md'; if (index < itemCount - 1 && itemArr[index + 1].status === StepStatusEnum.ERROR) { step.stepItemCls = step.stepItemCls ? Object.assign(step.stepItemCls, { 'error-tail': true }) : { 'error-tail': true }; } } } 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; } } ngOnInit() { this.setCls(); } ngAfterContentInit() { setTimeout(() => { this.setStepStyle(); }, 0); this.stepItems.changes.subscribe(change => { setTimeout(() => { this.setStepStyle(); }, 0); }); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: StepsComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: StepsComponent, selector: "Steps,nzm-steps", inputs: { current: "current", size: "size", status: "status", direction: "direction" }, host: { properties: { "class.am-steps": "this.clsSteps", "class.am-steps-small": "this.clsStepsSmall", "class.am-steps-label-vertical": "this.clsStepsLabelVtl", "class.am-steps-vertical": "this.clsStepsVtl", "class.am-steps-horizontal": "this.clsStepsHztl" } }, queries: [{ propertyName: "stepItems", predicate: StepComponent }], ngImport: i0, template: "<ng-content></ng-content>\n" }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: StepsComponent, decorators: [{ type: Component, args: [{ selector: 'Steps,nzm-steps', template: "<ng-content></ng-content>\n" }] }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], 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'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"steps.component.js","sourceRoot":"","sources":["../../../components/steps/steps.component.ts","../../../components/steps/steps.component.html"],"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;IAWzB,IACI,OAAO,CAAC,KAAK;QACf,IAAI,KAAK,IAAI,CAAC,EAAE;YACd,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,YAAY,EAAE,CAAC;aACrB;SACF;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;IAaD,YAAoB,IAAgB,EAAU,OAAkB;QAA5C,SAAI,GAAJ,IAAI,CAAY;QAAU,YAAO,GAAP,OAAO,CAAW;QAhDhE,cAAS,GAAW,UAAU,CAAC;QAEvB,aAAQ,GAAW,CAAC,CAAC;QAErB,YAAO,GAAmB,cAAc,CAAC,OAAO,CAAC;QACjD,eAAU,GAAsB,iBAAiB,CAAC,QAAQ,CAAC;QAiCnE,aAAQ,GAAY,IAAI,CAAC;IAU2C,CAAC;IAErE,YAAY;QACV,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;QACxC,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC3C,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,SAAS,EAAE,KAAK,EAAE,EAAE;YAC9C,MAAM,IAAI,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC;YAC5B,IAAI,CAAC,UAAU,GAAG,KAAK,GAAG,CAAC,CAAC;YAC5B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC;YAC9B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;YACtC,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,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;SACF;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,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC,EAAE,CAAC,CAAC,CAAC;QACN,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACxC,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,CAAC,EAAE,CAAC,CAAC,CAAC;QACR,CAAC,CAAC,CAAC;IACL,CAAC;8GAjGU,cAAc;kGAAd,cAAc,+aAQR,aAAa,6BC1BhC,6BACA;;2FDiBa,cAAc;kBAJ1B,SAAS;+BACE,iBAAiB;uGAY3B,SAAS;sBADR,eAAe;uBAAC,aAAa;gBAI1B,OAAO;sBADV,KAAK;gBAUF,IAAI;sBADP,KAAK;gBAMF,MAAM;sBADT,KAAK;gBAQF,SAAS;sBADZ,KAAK;gBAON,QAAQ;sBADP,WAAW;uBAAC,gBAAgB;gBAG7B,aAAa;sBADZ,WAAW;uBAAC,sBAAsB;gBAGnC,gBAAgB;sBADf,WAAW;uBAAC,+BAA+B;gBAG5C,WAAW;sBADV,WAAW;uBAAC,yBAAyB;gBAGtC,YAAY;sBADX,WAAW;uBAAC,2BAA2B","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\n  @ContentChildren(StepComponent)\n  stepItems: QueryList<StepComponent>;\n\n  @Input()\n  set current(value) {\n    if (value >= 0) {\n      this._current = value;\n      if (this.stepItems) {\n        this.setStepStyle();\n      }\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      step.outStatus = this._status;\n      step.currentIndex = this._current + 1;\n      step.iconSize = this._size === 'small' ? (this._status === StepStatusEnum.WAIT ? 'xxs' : 'xs') : 'md';\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    }\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    this.stepItems.changes.subscribe(change => {\n      setTimeout(() => {\n        this.setStepStyle();\n      }, 0);\n    });\n  }\n\n}\n","<ng-content></ng-content>\n"]}