UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

328 lines (327 loc) 19.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, ElementRef, Input, EventEmitter } from '@angular/core'; import { AbstractDataView } from '../../../component/dataview/AbstractDataView'; import { MaterialStepperModel } from '../model/MaterialStepperModel'; import { Option } from '../../../decorator/Option.decorator'; import { I18N } from '../../../decorator/I18N.decorator'; const /** @type {?} */ TYPE_NAME = "material-stepper"; export class MaterialStepper extends AbstractDataView { /** * @param {?} elementRef */ constructor(elementRef) { super(elementRef); this.editable = true; this.linear = false; this.stepInstances = !this.stepInstances ? [] : this.stepInstances; this.handler = (result) => { this.stepInstances.push(result.instance); }; } /** * @return {?} */ ngOnInit() { super.ngOnInit(); if (!this.model) { this.model = new MaterialStepperModel(); } } /** * @return {?} */ isSelfDataDirty() { return false; } /** * @return {?} */ selfSaveData() { } /** * @return {?} */ selfResetData() { } /** * @return {?} */ isHorizontal() { return this.horizontal; } /** * @param {?} horizontal * @return {?} */ setHorizontal(horizontal) { return this.horizontal = horizontal; } /** * @return {?} */ isLinear() { return this.linear; } /** * @param {?} linear * @return {?} */ setLinear(linear) { return this.linear = linear; } /** * @return {?} */ getModel() { return this.model; } /** * @param {?} model * @return {?} */ setModel(model) { this.model = model; } /** * @return {?} */ isEditable() { return this.editable; } /** * @param {?} editable * @return {?} */ setEditable(editable) { return this.editable = editable; } /** * @return {?} */ getEditIcon() { return this.editIcon; } /** * @param {?} editIcon * @return {?} */ setEditIcon(editIcon) { return this.editIcon = editIcon; } /** * @return {?} */ getDoneIcon() { return this.doneIcon; } /** * @param {?} doneIcon * @return {?} */ setDoneIcon(doneIcon) { return this.doneIcon = doneIcon; } /** * @return {?} */ getStepInstances() { return this.getDataChildren(); } /** * @param {?} index * @return {?} */ getStepInstance(index) { let /** @type {?} */ steps = this.getStepInstances(); if (!steps || index < 0 || steps.length <= index) { return null; } return steps[index]; } } MaterialStepper.TYPE_NAME = TYPE_NAME; MaterialStepper.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: `<mat-horizontal-stepper [linear]="true" #stepper> <mat-step label="Fill out your name"> <mat-form-field> <input matInput placeholder="Last name, First name"> </mat-form-field> <div> <button mat-button matStepperNext>Next</button> </div> </mat-step> <mat-step> <ng-template matStepLabel>Fill out your address</ng-template> <mat-form-field> <input matInput placeholder="Address"> </mat-form-field> <div> <button mat-button matStepperPrevious>Back</button> <button mat-button matStepperNext>Next</button> </div> </mat-step> <mat-step> <ng-template matStepLabel>Done</ng-template> You are now done. <div> <button mat-button matStepperPrevious>Back</button> <button mat-button (click)="stepper.reset()">Reset</button> </div> </mat-step> </mat-horizontal-stepper> ` },] }, ]; /** @nocollapse */ MaterialStepper.ctorParameters = () => [ { type: ElementRef, }, ]; MaterialStepper.propDecorators = { "dataParent": [{ type: Input },], "model": [{ type: Input },], "horizontal": [{ type: Input },], "linear": [{ type: Input },], "handler": [{ type: Input },], "editable": [{ type: Input },], "editIcon": [{ type: Input },], "doneIcon": [{ type: Input },], "stepInstances": [{ type: Input },], }; tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialStepper.prototype, "field", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], MaterialStepper.prototype, "dataParent", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialStepper.prototype, "ignoreParentData", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialStepper.prototype, "ignoreParentDisabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], MaterialStepper.prototype, "onDisabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], MaterialStepper.prototype, "onEnabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialStepper.prototype, "loadingEnabled", void 0); tslib_1.__decorate([ Option('load'), tslib_1.__metadata("design:type", EventEmitter) ], MaterialStepper.prototype, "loadEvent", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialStepper.prototype, "delegateHistory", void 0); tslib_1.__decorate([ Option(), I18N(), tslib_1.__metadata("design:type", MaterialStepperModel) ], MaterialStepper.prototype, "model", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialStepper.prototype, "horizontal", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialStepper.prototype, "linear", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], MaterialStepper.prototype, "handler", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], MaterialStepper.prototype, "editable", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialStepper.prototype, "editIcon", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], MaterialStepper.prototype, "doneIcon", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Array) ], MaterialStepper.prototype, "stepInstances", void 0); function MaterialStepper_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ MaterialStepper.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ MaterialStepper.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ MaterialStepper.propDecorators; /** @type {?} */ MaterialStepper.TYPE_NAME; /** @type {?} */ MaterialStepper.prototype.field; /** @type {?} */ MaterialStepper.prototype.dataParent; /** @type {?} */ MaterialStepper.prototype.ignoreParentData; /** @type {?} */ MaterialStepper.prototype.ignoreParentDisabled; /** @type {?} */ MaterialStepper.prototype.onDisabled; /** @type {?} */ MaterialStepper.prototype.onEnabled; /** @type {?} */ MaterialStepper.prototype.loadingEnabled; /** @type {?} */ MaterialStepper.prototype.loadEvent; /** @type {?} */ MaterialStepper.prototype.delegateHistory; /** @type {?} */ MaterialStepper.prototype.historyCursor; /** @type {?} */ MaterialStepper.prototype.histories; /** @type {?} */ MaterialStepper.prototype.elementRef; /** @type {?} */ MaterialStepper.prototype.dataChildren; /** @type {?} */ MaterialStepper.prototype.data; /** @type {?} */ MaterialStepper.prototype.kbShortcutService; /** @type {?} */ MaterialStepper.prototype._loaded; /** @type {?} */ MaterialStepper.prototype.model; /** @type {?} */ MaterialStepper.prototype.horizontal; /** @type {?} */ MaterialStepper.prototype.linear; /** @type {?} */ MaterialStepper.prototype.handler; /** @type {?} */ MaterialStepper.prototype.editable; /** @type {?} */ MaterialStepper.prototype.editIcon; /** @type {?} */ MaterialStepper.prototype.doneIcon; /** @type {?} */ MaterialStepper.prototype.stepInstances; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MaterialStepper.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/theme/material/component/MaterialStepper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, Output, HostListener, ViewChild, EventEmitter  } from '@angular/core';\r\nimport { AbstractDataView } from '../../../component/dataview/AbstractDataView';\r\nimport { MaterialStepperModel } from '../model/MaterialStepperModel';\r\nimport { Option } from '../../../decorator/Option.decorator';\r\nimport { I18N } from '../../../decorator/I18N.decorator';\r\nimport { IHasData } from '../../../component/IHasData';\r\nimport { UIHistory } from '../../../component/model/UIHistory';\r\nimport { KeyboardShortcutService } from '../../../service/KeyboardShortcutService.service';\r\n\r\n\r\ndeclare var $: any;\r\n\r\nconst TYPE_NAME: string = \"material-stepper\";\r\n\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: TYPE_NAME,\r\n  template: `<mat-horizontal-stepper [linear]=\"true\" #stepper>\r\n  <mat-step label=\"Fill out your name\">\r\n    <mat-form-field>\r\n      <input matInput placeholder=\"Last name, First name\">\r\n    </mat-form-field>\r\n    <div>\r\n      <button mat-button matStepperNext>Next</button>\r\n    </div>\r\n  </mat-step>\r\n  <mat-step>\r\n    <ng-template matStepLabel>Fill out your address</ng-template>\r\n    <mat-form-field>\r\n      <input matInput placeholder=\"Address\">\r\n    </mat-form-field>\r\n    <div>\r\n      <button mat-button matStepperPrevious>Back</button>\r\n      <button mat-button matStepperNext>Next</button>\r\n    </div>\r\n  </mat-step>\r\n  <mat-step>\r\n    <ng-template matStepLabel>Done</ng-template>\r\n    You are now done.\r\n    <div>\r\n      <button mat-button matStepperPrevious>Back</button>\r\n      <button mat-button (click)=\"stepper.reset()\">Reset</button>\r\n    </div>\r\n  </mat-step>\r\n</mat-horizontal-stepper>\r\n`\r\n})\r\nexport class MaterialStepper extends AbstractDataView implements OnInit {\r\n\r\n  public static readonly TYPE_NAME: string = TYPE_NAME;\r\n\r\n  // --- from AbstractDataView\r\n  @Option()\r\n  protected field: string;\r\n\r\n  // --- from AbstractHasData\r\n  @Option()\r\n  @Input()\r\n  protected dataParent: IHasData;\r\n  @Option()\r\n  protected ignoreParentData: boolean;\r\n  @Option()\r\n  protected ignoreParentDisabled: boolean;\r\n  @Option()\r\n  protected onDisabled: Function;\r\n  @Option()\r\n  protected onEnabled: Function;\r\n  @Option()\r\n  protected loadingEnabled: boolean;\r\n  @Option('load')\r\n  protected loadEvent: EventEmitter<any>;\r\n  @Option()\r\n  protected delegateHistory: boolean;\r\n\r\n  protected historyCursor: number;\r\n  protected histories: UIHistory[];\r\n  protected elementRef: ElementRef;\r\n  protected dataChildren: IHasData[];\r\n  protected data: any;\r\n\r\n  protected kbShortcutService: KeyboardShortcutService;\r\n\r\n  protected _loaded: boolean;\r\n\r\n  // --- from Self\r\n  @Option()\r\n  @Input()\r\n  @I18N()\r\n  protected model: MaterialStepperModel;\r\n\r\n  @Input()\r\n  @Option()\r\n  protected horizontal: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected linear: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected handler: Function;\r\n  @Input()\r\n  @Option()\r\n  protected editable: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected editIcon: string;\r\n  @Input()\r\n  @Option()\r\n  protected doneIcon: string;\r\n  @Input()\r\n  @Option()\r\n  protected stepInstances: any[];\r\n\r\n  constructor(elementRef: ElementRef) {\r\n    super(elementRef);\r\n\r\n    this.editable = true;\r\n    this.linear = false;\r\n\r\n    this.stepInstances = !this.stepInstances? [] : this.stepInstances;\r\n\r\n    this.handler = (result) => {\r\n      this.stepInstances.push(result.instance);\r\n    }\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n\r\n    if (!this.model) {\r\n      this.model = new MaterialStepperModel();\r\n    }\r\n  }\r\n\r\n  public isSelfDataDirty(): boolean {\r\n    return false;\r\n  }\r\n\r\n  public selfSaveData(): void {\r\n\r\n  }\r\n\r\n  public selfResetData(): void {\r\n\r\n  }\r\n\r\n  public isHorizontal(): boolean {\r\n    return this.horizontal;\r\n  }\r\n\r\n  public setHorizontal(horizontal: boolean): boolean {\r\n    return this.horizontal = horizontal;\r\n  }\r\n\r\n  public isLinear(): boolean {\r\n    return this.linear;\r\n  }\r\n\r\n  public setLinear(linear: boolean): boolean {\r\n    return this.linear = linear;\r\n  }\r\n\r\n  public getModel(): MaterialStepperModel {\r\n    return this.model;\r\n  }\r\n\r\n  public setModel(model: MaterialStepperModel): void {\r\n    this.model = model;\r\n  }\r\n\r\n  public isEditable(): boolean {\r\n    return this.editable;\r\n  }\r\n\r\n  public setEditable(editable: boolean): boolean {\r\n    return this.editable = editable;\r\n  }\r\n\r\n  public getEditIcon(): string {\r\n    return this.editIcon;\r\n  }\r\n\r\n  public setEditIcon(editIcon: string): string {\r\n    return this.editIcon = editIcon;\r\n  }\r\n\r\n  public getDoneIcon(): string {\r\n    return this.doneIcon;\r\n  }\r\n\r\n  public setDoneIcon(doneIcon: string): string {\r\n    return this.doneIcon = doneIcon;\r\n  }\r\n\r\n  public getStepInstances(): any[] {\r\n    return this.getDataChildren();\r\n  }\r\n\r\n  public getStepInstance(index: number): any {\r\n    let steps: any[] = this.getStepInstances();\r\n\r\n    if (!steps || index < 0 || steps.length <= index) {\r\n      return null;\r\n    }\r\n\r\n    return steps[index];\r\n  }\r\n\r\n}\r\n"]}