UNPKG

ng-zorro-antd-mobile

Version:

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

122 lines 17.7 kB
import { Component, forwardRef, Input, ElementRef, TemplateRef, ViewEncapsulation, HostBinding } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "ng-zorro-antd-mobile/icon"; export class StepComponent { get status() { return this._status; } set status(value) { if (value) { this._status = value; this.isCustomStatus = true; this.setIcon(); this.setClass(); } } get icon() { return this._icon; } set icon(value) { if (value) { this._icon = value; this.isCustomIcon = true; this.setClass(); } } set currentIndex(current) { this._currentIndex = current; if (!this.isCustomStatus) { this._status = current > this.stepNumber ? StepStatusEnum.FINISH : current === this.stepNumber ? this.outStatus || '' : StepStatusEnum.WAIT; this.setIcon(); this.setClass(); } } constructor(_el) { this._el = _el; this.prefixCls = 'am-steps'; this.stepItemCls = {}; this.iconCls = { [`${this.prefixCls}-icon`]: true }; this.isIconString = true; this.outStatus = 'process'; this.isCustomStatus = false; this.isCustomIcon = false; this.title = null; this.description = null; this._currentIndex = 0; this.clsStepItem = true; } isTemplateRef(value) { return value instanceof TemplateRef; } setClass() { this.stepItemCls = { [`${this.prefixCls}-item-${this.status}`]: true, [`${this.prefixCls}-item-custom`]: this.isCustomIcon || (this.icon && this._currentIndex !== this.stepNumber) }; } setIcon() { if (!this.isCustomIcon) { switch (this._status) { case StepStatusEnum.FINISH: this._icon = 'check-circle-o'; break; case StepStatusEnum.ERROR: this._icon = 'cross-circle-o'; break; case StepStatusEnum.WAIT: this._icon = 'ellipsis'; break; default: break; } } } ngOnInit() { } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: StepComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: StepComponent, selector: "Step, nzm-step", inputs: { status: "status", title: "title", description: "description", icon: "icon" }, host: { properties: { "class.am-steps-item": "this.clsStepItem" } }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => StepComponent), multi: true } ], ngImport: i0, template: "<div [ngClass]=\"stepItemCls\">\n <div class=\"{{ prefixCls }}-item-tail\">\n {{ tailContent }}\n </div>\n <div class=\"{{ prefixCls }}-item-icon\">\n <span *ngIf=\"isTemplateRef(icon)\" [ngClass]=\"iconCls\">\n <ng-template [ngTemplateOutlet]=\"icon\"></ng-template>\n </span>\n <span *ngIf=\"!isTemplateRef(icon) && (status === 'error' || status === 'finish' || status === 'wait')\" [ngClass]=\"iconCls\">\n <Icon [type]=\"icon\" [size]=\"iconSize\"> </Icon>\n </span>\n <span *ngIf=\"!isTemplateRef(icon) && !(status === 'error' || status === 'finish' || status === 'wait')\" [ngClass]=\"iconCls\"\n >{{ stepNumber }}\n </span>\n </div>\n <div class=\"{{ prefixCls }}-item-content\">\n <div class=\"{{ prefixCls }}-item-title\">\n <ng-container *ngIf=\"!isTemplateRef(title); else titleTemplate\">{{ title }}</ng-container>\n </div>\n <div *ngIf=\"description\" class=\"{{ prefixCls }}-item-description\">\n <ng-container *ngIf=\"!isTemplateRef(description); else descriptionTemplate\">{{ description }}</ng-container>\n </div>\n </div>\n</div>\n<ng-template #titleTemplate>\n <ng-template [ngTemplateOutlet]=\"title\"></ng-template>\n</ng-template>\n<ng-template #descriptionTemplate>\n <ng-template [ngTemplateOutlet]=\"description\"></ng-template>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.IconComponent, selector: "Icon, nzm-icon", inputs: ["color", "type", "src", "size"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: StepComponent, decorators: [{ type: Component, args: [{ selector: 'Step, nzm-step', encapsulation: ViewEncapsulation.None, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => StepComponent), multi: true } ], template: "<div [ngClass]=\"stepItemCls\">\n <div class=\"{{ prefixCls }}-item-tail\">\n {{ tailContent }}\n </div>\n <div class=\"{{ prefixCls }}-item-icon\">\n <span *ngIf=\"isTemplateRef(icon)\" [ngClass]=\"iconCls\">\n <ng-template [ngTemplateOutlet]=\"icon\"></ng-template>\n </span>\n <span *ngIf=\"!isTemplateRef(icon) && (status === 'error' || status === 'finish' || status === 'wait')\" [ngClass]=\"iconCls\">\n <Icon [type]=\"icon\" [size]=\"iconSize\"> </Icon>\n </span>\n <span *ngIf=\"!isTemplateRef(icon) && !(status === 'error' || status === 'finish' || status === 'wait')\" [ngClass]=\"iconCls\"\n >{{ stepNumber }}\n </span>\n </div>\n <div class=\"{{ prefixCls }}-item-content\">\n <div class=\"{{ prefixCls }}-item-title\">\n <ng-container *ngIf=\"!isTemplateRef(title); else titleTemplate\">{{ title }}</ng-container>\n </div>\n <div *ngIf=\"description\" class=\"{{ prefixCls }}-item-description\">\n <ng-container *ngIf=\"!isTemplateRef(description); else descriptionTemplate\">{{ description }}</ng-container>\n </div>\n </div>\n</div>\n<ng-template #titleTemplate>\n <ng-template [ngTemplateOutlet]=\"title\"></ng-template>\n</ng-template>\n<ng-template #descriptionTemplate>\n <ng-template [ngTemplateOutlet]=\"description\"></ng-template>\n</ng-template>\n" }] }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { status: [{ type: Input }], title: [{ type: Input }], description: [{ type: Input }], icon: [{ type: Input }], clsStepItem: [{ type: HostBinding, args: ['class.am-steps-item'] }] } }); export var StepStatusEnum; (function (StepStatusEnum) { StepStatusEnum["WAIT"] = "wait"; StepStatusEnum["PROCESS"] = "process"; StepStatusEnum["FINISH"] = "finish"; StepStatusEnum["ERROR"] = "error"; })(StepStatusEnum || (StepStatusEnum = {})); export var StepDirectionEnum; (function (StepDirectionEnum) { StepDirectionEnum["VERTICAL"] = "vertical"; StepDirectionEnum["HORIZONTAL"] = "horizontal"; })(StepDirectionEnum || (StepDirectionEnum = {})); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"step.component.js","sourceRoot":"","sources":["../../../../components/steps/step/step.component.ts","../../../../components/steps/step/step.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  forwardRef,\n  Input,\n  ElementRef,\n  TemplateRef,\n  ViewEncapsulation,\n  HostBinding\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'Step, nzm-step',\n  templateUrl: './step.component.html',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => StepComponent),\n      multi: true\n    }\n  ]\n})\nexport class StepComponent implements OnInit {\n  prefixCls = 'am-steps';\n  stepItemCls = {};\n  iconCls: object = {\n    [`${this.prefixCls}-icon`]: true\n  };\n  tailContent: string;\n  stepNumber: number;\n  isIconString: boolean = true;\n  iconSize: string;\n  outStatus = 'process';\n\n  private _status: StepStatusEnum;\n  private _icon: string | TemplateRef<any>;\n  private isCustomStatus = false;\n  private isCustomIcon = false;\n\n  @Input()\n  get status(): StepStatusEnum {\n    return this._status;\n  }\n  set status(value: StepStatusEnum) {\n    if (value) {\n      this._status = value;\n      this.isCustomStatus = true;\n      this.setIcon();\n      this.setClass();\n    }\n  }\n  @Input()\n  title: string | TemplateRef<any> = null;\n  @Input()\n  description: string | TemplateRef<any> = null;\n  @Input()\n  get icon(): string | TemplateRef<any> {\n    return this._icon;\n  }\n  set icon(value: string | TemplateRef<any>) {\n    if (value) {\n      this._icon = value;\n      this.isCustomIcon = true;\n      this.setClass();\n    }\n  }\n\n  set currentIndex(current: number) {\n    this._currentIndex = current;\n    if (!this.isCustomStatus) {\n      this._status = current > this.stepNumber ? StepStatusEnum.FINISH : current === this.stepNumber ?\n        this.outStatus || ('' as any) : StepStatusEnum.WAIT;\n      this.setIcon();\n      this.setClass();\n    }\n  }\n\n  private _currentIndex = 0;\n\n  @HostBinding('class.am-steps-item')\n  clsStepItem: boolean = true;\n\n  constructor(private _el: ElementRef) { }\n\n  isTemplateRef(value) {\n    return value instanceof TemplateRef;\n  }\n\n  setClass() {\n    this.stepItemCls = {\n      [`${this.prefixCls}-item-${this.status}`]: true,\n      [`${this.prefixCls}-item-custom`]: this.isCustomIcon || (this.icon && this._currentIndex !== this.stepNumber)\n    };\n  }\n\n  setIcon() {\n    if (!this.isCustomIcon) {\n      switch (this._status) {\n        case StepStatusEnum.FINISH:\n          this._icon = 'check-circle-o';\n          break;\n        case StepStatusEnum.ERROR:\n          this._icon = 'cross-circle-o';\n          break;\n        case StepStatusEnum.WAIT:\n          this._icon = 'ellipsis';\n          break;\n        default:\n          break;\n      }\n    }\n  }\n\n  ngOnInit() { }\n}\n\nexport enum StepStatusEnum {\n  WAIT = 'wait',\n  PROCESS = 'process',\n  FINISH = 'finish',\n  ERROR = 'error'\n}\nexport enum StepDirectionEnum {\n  VERTICAL = 'vertical',\n  HORIZONTAL = 'horizontal'\n}\n","<div [ngClass]=\"stepItemCls\">\n  <div class=\"{{ prefixCls }}-item-tail\">\n    {{ tailContent }}\n  </div>\n  <div class=\"{{ prefixCls }}-item-icon\">\n    <span *ngIf=\"isTemplateRef(icon)\" [ngClass]=\"iconCls\">\n      <ng-template [ngTemplateOutlet]=\"icon\"></ng-template>\n    </span>\n    <span *ngIf=\"!isTemplateRef(icon) && (status === 'error' || status === 'finish' || status === 'wait')\" [ngClass]=\"iconCls\">\n      <Icon [type]=\"icon\" [size]=\"iconSize\"> </Icon>\n    </span>\n    <span *ngIf=\"!isTemplateRef(icon) && !(status === 'error' || status === 'finish' || status === 'wait')\" [ngClass]=\"iconCls\"\n      >{{ stepNumber }}\n    </span>\n  </div>\n  <div class=\"{{ prefixCls }}-item-content\">\n    <div class=\"{{ prefixCls }}-item-title\">\n      <ng-container *ngIf=\"!isTemplateRef(title); else titleTemplate\">{{ title }}</ng-container>\n    </div>\n    <div *ngIf=\"description\" class=\"{{ prefixCls }}-item-description\">\n      <ng-container *ngIf=\"!isTemplateRef(description); else descriptionTemplate\">{{ description }}</ng-container>\n    </div>\n  </div>\n</div>\n<ng-template #titleTemplate>\n  <ng-template [ngTemplateOutlet]=\"title\"></ng-template>\n</ng-template>\n<ng-template #descriptionTemplate>\n  <ng-template [ngTemplateOutlet]=\"description\"></ng-template>\n</ng-template>\n"]}