com.phloxui
Version:
PhloxUI Ng2+ Framework
328 lines (327 loc) • 19.9 kB
JavaScript
/**
* @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"]}