UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

340 lines (339 loc) 27.2 kB
/** * @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 { AbstractDataView } from '../dataview/AbstractDataView'; import { Option } from '../../decorator/Option.decorator'; /** * @abstract */ var AbstractWizardPane = /** @class */ (function (_super) { tslib_1.__extends(AbstractWizardPane, _super); function AbstractWizardPane(appSvc, elementRef) { var _this = _super.call(this, elementRef) || this; _this.currentStep = -1; _this.phloxAppService = appSvc; _this.changeEvent = new EventEmitter(); _this.beforeChangeEvent = new EventEmitter(); _this.stepInstances = !_this.stepInstances ? [] : _this.stepInstances; _this.stepsComponentHandler = function (data) { _this.stepInstances.push(data.instance); if (typeof data.instance.getBeforeChangeEvent === 'function') { var /** @type {?} */ beforeChangeEmitter = data.instance.getBeforeChangeEvent(); if (beforeChangeEmitter !== null && typeof beforeChangeEmitter !== 'undefined') { beforeChangeEmitter.subscribe(function (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 // event.wizardStepIndex = ; //! add wizard step index _this.beforeChangeEvent.emit(event); }); } } if (typeof data.instance.getChangeEvent === 'function') { var /** @type {?} */ changeEmitter = data.instance.getChangeEvent(); if (changeEmitter !== null && typeof changeEmitter !== 'undefined') { changeEmitter.subscribe(function (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 // event.wizardStepIndex = ; //! add wizard step index _this.changeEvent.emit(event); }); } } }; return _this; } Object.defineProperty(AbstractWizardPane.prototype, "app", { get: /** * @return {?} */ function () { if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') { return null; } return this.phloxAppService.getInstance(); }, enumerable: true, configurable: true }); /** * @return {?} */ AbstractWizardPane.prototype.ngOnInit = /** * @return {?} */ function () { this.stepSelected(0); if (this.model !== null && this.model !== undefined && this.model.header !== null) { this.headerHeight = this.model.header.height; } if (this.model !== null && this.model !== undefined && this.model.footer !== null) { this.footerHeight = this.model.footer.height; } // set default if (this.headerHeight === null || this.headerHeight === undefined) { if (this.app !== null && this.app !== undefined) { this.headerHeight = this.app.getAppInfo().settings.WIZARD_HEADER_HEIGHT; } } if (this.footerHeight === null || this.footerHeight === undefined) { if (this.app !== null && this.app !== undefined) { this.footerHeight = this.app.getAppInfo().settings.WIZARD_FOOTER_HEIGHT; } } }; /** * @return {?} */ AbstractWizardPane.prototype.getModel = /** * @return {?} */ function () { return this.model; }; /** * @param {?} model * @return {?} */ AbstractWizardPane.prototype.setModel = /** * @param {?} model * @return {?} */ function (model) { this.model = model; }; /** * @param {?} index * @return {?} */ AbstractWizardPane.prototype.stepSelected = /** * @param {?} index * @return {?} */ function (index) { if (index === null) { return; } this.currentStep = index; this.showStepContent(index); }; /** * @param {?} index * @return {?} */ AbstractWizardPane.prototype.isStepSelected = /** * @param {?} index * @return {?} */ function (index) { if (index === null) { return; } if (this.currentStep !== null && this.currentStep > -1) { if (this.currentStep == index) { return true; } } return false; }; /** * @return {?} */ AbstractWizardPane.prototype.getChangeEvent = /** * @return {?} */ function () { return this.changeEvent; }; /** * @param {?} event * @return {?} */ AbstractWizardPane.prototype.setChangeEvent = /** * @param {?} event * @return {?} */ function (event) { this.changeEvent = event; }; /** * @return {?} */ AbstractWizardPane.prototype.getBeforeChangeEvent = /** * @return {?} */ function () { return this.beforeChangeEvent; }; /** * @param {?} event * @return {?} */ AbstractWizardPane.prototype.setBeforeChangeEvent = /** * @param {?} event * @return {?} */ function (event) { this.beforeChangeEvent = event; }; /** * @return {?} */ AbstractWizardPane.prototype.isSelfDataDirty = /** * @return {?} */ function () { return false; }; /** * @param {?} data * @return {?} */ AbstractWizardPane.prototype.selfSaveData = /** * @param {?} data * @return {?} */ function (data) { }; /** * @return {?} */ AbstractWizardPane.prototype.selfResetData = /** * @return {?} */ function () { }; /** * @return {?} */ AbstractWizardPane.prototype.doPreload = /** * @return {?} */ function () { return new Promise(function (resolve, reject) { resolve(null); }); }; /** * @return {?} */ AbstractWizardPane.prototype.doLoaded = /** * @return {?} */ function () { }; /** * @return {?} */ AbstractWizardPane.prototype.getHeaderHeight = /** * @return {?} */ function () { return this.headerHeight; }; /** * @return {?} */ AbstractWizardPane.prototype.getFooterHeight = /** * @return {?} */ function () { return this.footerHeight; }; /** * @return {?} */ AbstractWizardPane.prototype.getStepsComponentHandler = /** * @return {?} */ function () { return this.stepsComponentHandler; }; /** * @return {?} */ AbstractWizardPane.prototype.getStepInstances = /** * @return {?} */ function () { return this.getDataChildren(); }; /** * @param {?} index * @return {?} */ AbstractWizardPane.prototype.getStepInstance = /** * @param {?} index * @return {?} */ function (index) { var /** @type {?} */ steps = this.getStepInstances(); if (!steps || index < 0 || steps.length <= index) { return null; } return steps[index]; }; AbstractWizardPane.propDecorators = { "model": [{ type: Input },], }; tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", WizardModel) ], AbstractWizardPane.prototype, "model", void 0); tslib_1.__decorate([ Option('change'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractWizardPane.prototype, "changeEvent", void 0); tslib_1.__decorate([ Option('beforeChange'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractWizardPane.prototype, "beforeChangeEvent", void 0); return AbstractWizardPane; }(AbstractDataView)); export { AbstractWizardPane }; 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.beforeChangeEvent; /** @type {?} */ AbstractWizardPane.prototype.stepsComponentHandler; /** @type {?} */ AbstractWizardPane.prototype.stepInstances; /** * @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/dataview/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 { AbstractHasDataHelp } from '../AbstractHasDataHelp';\r\nimport { AbstractDataView } from '../dataview/AbstractDataView';\r\nimport { IChangeable } from '../IChangeable';\r\nimport { Option } from '../../decorator/Option.decorator';\r\nimport { I18N } from '../../decorator/I18N.decorator';\r\n\r\nexport abstract class AbstractWizardPane extends AbstractDataView implements OnInit, IHasModel, IChangeable {\r\n\r\n  @Input()\r\n  @Option()\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  @Option('beforeChange')\r\n  protected beforeChangeEvent: EventEmitter<any>;\r\n  protected stepsComponentHandler: Function;\r\n  protected stepInstances: any[];\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    this.beforeChangeEvent = new EventEmitter();\r\n\r\n    this.stepInstances = !this.stepInstances? [] : this.stepInstances;\r\n\r\n    this.stepsComponentHandler = (data: any) => {\r\n      this.stepInstances.push(data.instance);\r\n\r\n      if (typeof data.instance.getBeforeChangeEvent === 'function') {\r\n        let beforeChangeEmitter = data.instance.getBeforeChangeEvent();\r\n        if (beforeChangeEmitter !== null && typeof beforeChangeEmitter !== 'undefined') {\r\n          beforeChangeEmitter.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.beforeChangeEvent.emit(event);\r\n          });\r\n        }\r\n      }\r\n\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 !== undefined && this.model.header !== null) {\r\n      this.headerHeight = this.model.header.height;\r\n    }\r\n    if (this.model !== null && this.model !== undefined && 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 || this.headerHeight === undefined) {\r\n      if (this.app !== null && this.app !== undefined) {\r\n        this.headerHeight = this.app.getAppInfo().settings.WIZARD_HEADER_HEIGHT;\r\n      }\r\n    }\r\n    if (this.footerHeight === null || this.footerHeight === undefined) {\r\n      if (this.app !== null && this.app !== undefined) {\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 getBeforeChangeEvent(): EventEmitter<any> {\r\n    return this.beforeChangeEvent;\r\n  }\r\n\r\n  public setBeforeChangeEvent(event: EventEmitter<any>): void {\r\n    this.beforeChangeEvent = event;\r\n  }\r\n\r\n  public isSelfDataDirty(): boolean {\r\n    return false;\r\n  }\r\n\r\n  public selfSaveData(data: any): 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  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"]}