UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

179 lines (178 loc) 15.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import { PhloxAppInfo } from '../component/model/PhloxAppInfo'; /** * <p style="text-indent: 2em;"> * An abstract base class of <code>PhloxUI</code> application's <code>page</code>. All component classes extending this class can be * added into [[PhloxApp]] component and can be navigated via its <code>router</code>. * </p> * * @author shiorin, tee4cute * @see [[PhloxApp]] * @abstract */ var /** * <p style="text-indent: 2em;"> * An abstract base class of <code>PhloxUI</code> application's <code>page</code>. All component classes extending this class can be * added into [[PhloxApp]] component and can be navigated via its <code>router</code>. * </p> * * @author shiorin, tee4cute * @see [[PhloxApp]] * @abstract */ AbstractPage = /** @class */ (function () { /** * This constructor will automatically add <code><b>this</b></code> <code>page</code> instance into the given [[PhloxApp]] <code>application</code> (<code><b>app</b></code>). */ function AbstractPage(phloxAppService, name, bgProcessMgr) { this.PAGE_LOOP_TIMEOUT = 5; this.name = name; this.bgProcessMgr = bgProcessMgr; if (phloxAppService !== null && typeof phloxAppService !== 'undefined') { this.phloxAppService = phloxAppService; if (this.app !== null && typeof this.app !== 'undefined') { // Add this page instance to app this.app.addItem(this); } } } Object.defineProperty(AbstractPage.prototype, "app", { get: /** * A [[PhloxApp]] component in which this <code>page</code> is associated with. * @return {?} */ function () { if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') { return null; } return this.phloxAppService.getInstance(); }, enumerable: true, configurable: true }); /** * @return {?} */ AbstractPage.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; if (this.bgProcessMgr !== null && typeof this.bgProcessMgr !== 'undefined') { this.bgProcessMgr.execute(function () { return new Promise(function (resolve, reject) { var /** @type {?} */ timeout = PhloxAppInfo.DEFAULT_PAGE_LOAD_TIMEOUT; if (_this.app !== null && typeof _this.app !== 'undefined') { var /** @type {?} */ info = _this.app.getAppInfo(); if (info !== null && typeof info !== 'undefined' && info.settings.PAGE_LOAD_TIMEOUT !== null && typeof info.settings.PAGE_LOAD_TIMEOUT !== 'undefined') { timeout = info.settings.PAGE_LOAD_TIMEOUT; } } var /** @type {?} */ startTime = null; var /** @type {?} */ handler = function () { if (startTime === null) { startTime = (new Date()).getTime(); } var /** @type {?} */ currentTime = (new Date()).getTime(); if (_this.isPageLoaded()) { resolve(); } else if ((currentTime - startTime) >= timeout) { reject(); } else { setTimeout(handler, _this.PAGE_LOOP_TIMEOUT); } }; handler(); }); }, { type: "connection.page" }); } }; /** * <p style="text-indent: 1em;"> * Get an <code>application</code> instance in which this <code>page</code> is associated with. * </p> * @return {?} */ AbstractPage.prototype.getApplication = /** * <p style="text-indent: 1em;"> * Get an <code>application</code> instance in which this <code>page</code> is associated with. * </p> * @return {?} */ function () { return this.app; }; /** * <p style="text-indent: 1em;"> * Get a name of this <code>page</code>. This must be also a <code>router</code>'s uri path. * </p> * @return {?} */ AbstractPage.prototype.getName = /** * <p style="text-indent: 1em;"> * Get a name of this <code>page</code>. This must be also a <code>router</code>'s uri path. * </p> * @return {?} */ function () { return this.name; }; /** * <p style="text-indent: 1em;"> * To check that this <code>page</code> is being showed or displayed by [[PhloxApp]] component or not. * </p> * @return {?} */ AbstractPage.prototype.isActive = /** * <p style="text-indent: 1em;"> * To check that this <code>page</code> is being showed or displayed by [[PhloxApp]] component or not. * </p> * @return {?} */ function () { return this.active; }; return AbstractPage; }()); /** * <p style="text-indent: 2em;"> * An abstract base class of <code>PhloxUI</code> application's <code>page</code>. All component classes extending this class can be * added into [[PhloxApp]] component and can be navigated via its <code>router</code>. * </p> * * @author shiorin, tee4cute * @see [[PhloxApp]] * @abstract */ export { AbstractPage }; function AbstractPage_tsickle_Closure_declarations() { /** @type {?} */ AbstractPage.prototype.PAGE_LOOP_TIMEOUT; /** @type {?} */ AbstractPage.prototype.phloxAppService; /** @type {?} */ AbstractPage.prototype.bgProcessMgr; /** * A flag indicating that this <code>page</code> is being showed or displayed by [[PhloxApp]] component or not. * @type {?} */ AbstractPage.prototype.active; /** * A name of this <code>page</code>. This must be also a <code>router</code>'s uri path. * @type {?} */ AbstractPage.prototype.name; /** * @abstract * @return {?} */ AbstractPage.prototype.isPageLoaded = function () { }; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractPage.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/AbstractPage.ts"],"names":[],"mappings":"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","sourcesContent":["import { OnInit } from '@angular/core';\nimport { PhloxApp } from './PhloxApp.component';\nimport { INavigatee } from './INavigatee';\nimport { IApplicationAware } from './IApplicationAware';\nimport { IPageLoad } from '../share/IPageLoad';\nimport { PhloxAppService } from '../service/PhloxAppService.service';\nimport { BackgroundProcessManager } from '../service/BackgroundProcessManager.service';\nimport { PhloxAppInfo } from '../component/model/PhloxAppInfo';\n\n/**\n * <p style=\"text-indent: 2em;\">\n * An abstract base class of <code>PhloxUI</code> application's <code>page</code>. All component classes extending this class can be\n * added into [[PhloxApp]] component and can be navigated via its <code>router</code>.\n * </p>\n *\n * @author shiorin, tee4cute\n * @see [[PhloxApp]]\n */\nexport abstract class AbstractPage implements INavigatee, IApplicationAware, OnInit, IPageLoad {\n\n    private PAGE_LOOP_TIMEOUT: number = 5;\n    protected phloxAppService: PhloxAppService;\n    protected bgProcessMgr: BackgroundProcessManager;\n\n    /**\n     * A [[PhloxApp]] component in which this <code>page</code> is associated with.\n     */\n    private get app(): PhloxApp {\n        if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') {\n            return null;\n        }\n        return this.phloxAppService.getInstance();\n    }\n\n    /**\n     * A flag indicating that this <code>page</code> is being showed or displayed by [[PhloxApp]] component or not.\n     */\n    public active: boolean;\n\n    /**\n     * A name of this <code>page</code>. This must be also a <code>router</code>'s uri path.\n     */\n    protected name: string;\n\n    /**\n     * This constructor will automatically add <code><b>this</b></code> <code>page</code> instance into the given [[PhloxApp]] <code>application</code> (<code><b>app</b></code>).\n     */\n    constructor(phloxAppService: PhloxAppService, name: string, bgProcessMgr: BackgroundProcessManager) {\n        this.name = name;\n        this.bgProcessMgr = bgProcessMgr;\n\n        if (phloxAppService !== null && typeof phloxAppService !== 'undefined') {\n            this.phloxAppService = phloxAppService;\n\n            if (this.app !== null && typeof this.app !== 'undefined') {\n                // Add this page instance to app\n                this.app.addItem(this);\n            }\n        }\n    }\n\n    public ngOnInit(): void {\n      if(this.bgProcessMgr !== null && typeof this.bgProcessMgr !== 'undefined'){\n          this.bgProcessMgr.execute(() => {\n            return new Promise((resolve, reject) => {\n\n              let timeout = PhloxAppInfo.DEFAULT_PAGE_LOAD_TIMEOUT;\n              if (this.app !== null && typeof this.app !== 'undefined') {\n                let info = this.app.getAppInfo();\n                if(info !== null && typeof info !== 'undefined' && info.settings.PAGE_LOAD_TIMEOUT !== null && typeof info.settings.PAGE_LOAD_TIMEOUT !== 'undefined'){\n                  timeout = info.settings.PAGE_LOAD_TIMEOUT;\n                }\n              }\n\n              let startTime: any = null;\n              let handler: Function = () => {\n\n                if(startTime === null){\n                  startTime = (new Date()).getTime();\n                }\n                let currentTime: any = (new Date()).getTime();\n                if (this.isPageLoaded()) {\n                  resolve();\n                } else if ((currentTime - startTime) >= timeout) {\n                  reject();\n                } else {\n                  setTimeout(handler, this.PAGE_LOOP_TIMEOUT);\n                }\n\n              };\n\n              handler();\n            });\n          }, {\n              type: \"connection.page\"\n          });\n      }\n    }\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Get an <code>application</code> instance in which this <code>page</code> is associated with.\n     * </p>\n     */\n    public getApplication(): PhloxApp {\n        return this.app;\n    }\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Get a name of this <code>page</code>. This must be also a <code>router</code>'s uri path.\n     * </p>\n     */\n    public getName(): string {\n        return this.name;\n    }\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * To check that this <code>page</code> is being showed or displayed by [[PhloxApp]] component or not.\n     * </p>\n     */\n    public isActive(): boolean {\n        return this.active;\n    }\n\n    public abstract isPageLoaded(): boolean;\n}\n"]}