com.phloxui
Version:
PhloxUI Ng2+ Framework
205 lines (204 loc) • 16.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Input, EventEmitter } from '@angular/core';
import { WizardModel } from './model/WizardModel';
import { AbstractHasData } from './AbstractHasData';
import { Option } from '../decorator/Option.decorator';
/**
* @abstract
*/
export class AbstractWizardPane extends AbstractHasData {
/**
* @param {?} appSvc
* @param {?} elementRef
*/
constructor(appSvc, elementRef) {
super(elementRef);
this.currentStep = -1;
this.phloxAppService = appSvc;
this.changeEvent = new EventEmitter();
this.stepsComponentHandler = (data) => {
if (typeof data.instance.getChangeEvent === 'function') {
let /** @type {?} */ changeEmitter = data.instance.getChangeEvent();
if (changeEmitter !== null && typeof changeEmitter !== 'undefined') {
changeEmitter.subscribe((event) => {
if (event.detail !== null && typeof event.detail !== 'undefined') {
if (event.detail.data !== null && typeof event.detail.data !== 'undefined') {
if (event.detail.data.bubbleStack !== null && typeof event.detail.data.bubbleStack !== 'undefined') {
event.detail.data.bubbleStack.push(this);
}
else {
event.detail.data.bubbleStack = [this];
}
}
}
// event.wizardStepIndex = ; //! add wizard step index
this.changeEvent.emit(event);
});
}
}
};
}
/**
* @return {?}
*/
get app() {
if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') {
return null;
}
return this.phloxAppService.getInstance();
}
/**
* @return {?}
*/
ngOnInit() {
this.stepSelected(0);
if (this.model !== null && this.model.header !== null) {
this.headerHeight = this.model.header.height;
}
if (this.model !== null && this.model.footer !== null) {
this.footerHeight = this.model.footer.height;
}
// set default
if (this.headerHeight === null) {
if (this.app !== null) {
this.headerHeight = this.app.getAppInfo().settings.WIZARD_HEADER_HEIGHT;
}
}
if (this.footerHeight === null) {
if (this.app !== null) {
this.footerHeight = this.app.getAppInfo().settings.WIZARD_FOOTER_HEIGHT;
}
}
}
/**
* @return {?}
*/
getModel() {
return this.model;
}
/**
* @param {?} model
* @return {?}
*/
setModel(model) {
this.model = model;
}
/**
* @param {?} index
* @return {?}
*/
stepSelected(index) {
if (index === null) {
return;
}
this.currentStep = index;
this.showStepContent(index);
}
/**
* @param {?} index
* @return {?}
*/
isStepSelected(index) {
if (index === null) {
return;
}
if (this.currentStep !== null && this.currentStep > -1) {
if (this.currentStep == index) {
return true;
}
}
return false;
}
/**
* @return {?}
*/
getChangeEvent() {
return this.changeEvent;
}
/**
* @param {?} event
* @return {?}
*/
setChangeEvent(event) {
this.changeEvent = event;
}
/**
* @return {?}
*/
isSelfDataDirty() {
return false;
}
/**
* @return {?}
*/
selfSaveData() {
}
/**
* @return {?}
*/
selfResetData() {
}
/**
* @return {?}
*/
doPreload() { return new Promise((resolve, reject) => { resolve(null); }); }
/**
* @return {?}
*/
doLoaded() {
}
/**
* @return {?}
*/
getHeaderHeight() {
return this.headerHeight;
}
/**
* @return {?}
*/
getFooterHeight() {
return this.footerHeight;
}
/**
* @return {?}
*/
getStepsComponentHandler() {
return this.stepsComponentHandler;
}
}
AbstractWizardPane.propDecorators = {
"model": [{ type: Input },],
};
tslib_1.__decorate([
Option('change'),
tslib_1.__metadata("design:type", EventEmitter)
], AbstractWizardPane.prototype, "changeEvent", void 0);
function AbstractWizardPane_tsickle_Closure_declarations() {
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
AbstractWizardPane.propDecorators;
/** @type {?} */
AbstractWizardPane.prototype.model;
/** @type {?} */
AbstractWizardPane.prototype.currentStep;
/** @type {?} */
AbstractWizardPane.prototype.headerHeight;
/** @type {?} */
AbstractWizardPane.prototype.footerHeight;
/** @type {?} */
AbstractWizardPane.prototype.phloxAppService;
/** @type {?} */
AbstractWizardPane.prototype.changeEvent;
/** @type {?} */
AbstractWizardPane.prototype.stepsComponentHandler;
/**
* @abstract
* @param {?} index
* @return {?}
*/
AbstractWizardPane.prototype.showStepContent = function (index) { };
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractWizardPane.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/AbstractWizardPane.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, ViewChild, EventEmitter } from '@angular/core';\r\nimport { WizardModel } from './model/WizardModel';\r\nimport { WizardStepModel } from './model/models';\r\n\r\nimport { PhloxAppService } from '../service/PhloxAppService.service';\r\nimport { IHasModel } from './IHasModel';\r\nimport { IHasData } from './IHasData';\r\nimport { PhloxApp } from './PhloxApp.component';\r\nimport { AbstractHasData } from './AbstractHasData';\r\nimport { IChangeable } from './IChangeable';\r\nimport { Option } from '../decorator/Option.decorator';\r\n\r\nexport abstract class AbstractWizardPane extends AbstractHasData implements OnInit, IHasModel, IChangeable {\r\n\r\n  @Input()\r\n  protected model: WizardModel;\r\n  protected currentStep: number;\r\n  protected headerHeight: number;\r\n  protected footerHeight: number;\r\n  protected phloxAppService: PhloxAppService;\r\n  @Option('change')\r\n  protected changeEvent: EventEmitter<any>;\r\n  protected stepsComponentHandler: Function;\r\n\r\n  private get app(): PhloxApp {\r\n    if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') {\r\n      return null;\r\n    }\r\n    return this.phloxAppService.getInstance();\r\n  }\r\n\r\n  constructor(appSvc: PhloxAppService, elementRef: ElementRef) {\r\n    super(elementRef);\r\n    this.currentStep = -1;\r\n    this.phloxAppService = appSvc;\r\n    this.changeEvent = new EventEmitter();\r\n\r\n    this.stepsComponentHandler = (data: any) => {\r\n      if (typeof data.instance.getChangeEvent === 'function') {\r\n        let changeEmitter = data.instance.getChangeEvent();\r\n        if (changeEmitter !== null && typeof changeEmitter !== 'undefined') {\r\n          changeEmitter.subscribe((event: any) => {\r\n            if (event.detail !== null && typeof event.detail !== 'undefined') {\r\n              if (event.detail.data !== null && typeof event.detail.data !== 'undefined') {\r\n                if (event.detail.data.bubbleStack !== null && typeof event.detail.data.bubbleStack !== 'undefined') {\r\n                  event.detail.data.bubbleStack.push(this);\r\n                } else {\r\n                  event.detail.data.bubbleStack = [this];\r\n                }\r\n              }\r\n            }\r\n            //                    event.wizardStepIndex = ; //! add wizard step index\r\n            this.changeEvent.emit(event);\r\n          });\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.stepSelected(0);\r\n\r\n    if (this.model !== null && this.model.header !== null) {\r\n      this.headerHeight = this.model.header.height;\r\n    }\r\n    if (this.model !== null && this.model.footer !== null) {\r\n      this.footerHeight = this.model.footer.height;\r\n    }\r\n\r\n    // set default\r\n    if (this.headerHeight === null) {\r\n      if (this.app !== null) {\r\n        this.headerHeight = this.app.getAppInfo().settings.WIZARD_HEADER_HEIGHT;\r\n      }\r\n    }\r\n    if (this.footerHeight === null) {\r\n      if (this.app !== null) {\r\n        this.footerHeight = this.app.getAppInfo().settings.WIZARD_FOOTER_HEIGHT;\r\n      }\r\n    }\r\n  }\r\n\r\n  public abstract showStepContent(index: number): void;\r\n\r\n  public getModel(): WizardModel {\r\n    return this.model;\r\n  }\r\n\r\n  public setModel(model: WizardModel): void {\r\n    this.model = model;\r\n  }\r\n\r\n  public stepSelected(index: number): void {\r\n    if (index === null) {\r\n      return;\r\n    }\r\n    this.currentStep = index;\r\n\r\n    this.showStepContent(index);\r\n  }\r\n\r\n  public isStepSelected(index: number): boolean {\r\n    if (index === null) {\r\n      return;\r\n    }\r\n    if (this.currentStep !== null && this.currentStep > -1) {\r\n      if (this.currentStep == index) {\r\n        return true;\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public getChangeEvent(): EventEmitter<any> {\r\n    return this.changeEvent;\r\n  }\r\n\r\n  public setChangeEvent(event: EventEmitter<any>): void {\r\n    this.changeEvent = event;\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 doPreload(): Promise<any> {     return new Promise((resolve, reject) => {       resolve(null);     });   }  public doLoaded(): void {\r\n\r\n  }\r\n\r\n  public getHeaderHeight(): number {\r\n    return this.headerHeight;\r\n  }\r\n\r\n  public getFooterHeight(): number {\r\n    return this.footerHeight;\r\n  }\r\n\r\n  public getStepsComponentHandler(): Function {\r\n    return this.stepsComponentHandler;\r\n  }\r\n\r\n}\r\n"]}