com.phloxui
Version:
PhloxUI Ng2+ Framework
134 lines (133 loc) • 13.9 kB
JavaScript
/**
* @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
*/
export class AbstractPage {
/**
* 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>).
* @param {?} phloxAppService
* @param {?} name
* @param {?} bgProcessMgr
*/
constructor(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);
}
}
}
/**
* A [[PhloxApp]] component in which this <code>page</code> is associated with.
* @return {?}
*/
get app() {
if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') {
return null;
}
return this.phloxAppService.getInstance();
}
/**
* @return {?}
*/
ngOnInit() {
if (this.bgProcessMgr !== null && typeof this.bgProcessMgr !== 'undefined') {
this.bgProcessMgr.execute(() => {
return new Promise((resolve, reject) => {
let /** @type {?} */ timeout = PhloxAppInfo.DEFAULT_PAGE_LOAD_TIMEOUT;
if (this.app !== null && typeof this.app !== 'undefined') {
let /** @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;
}
}
let /** @type {?} */ startTime = null;
let /** @type {?} */ handler = () => {
if (startTime === null) {
startTime = (new Date()).getTime();
}
let /** @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 {?}
*/
getApplication() {
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 {?}
*/
getName() {
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 {?}
*/
isActive() {
return this.active;
}
}
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"]}