com.phloxui
Version:
PhloxUI Ng2+ Framework
145 lines (144 loc) • 13.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component } from '@angular/core';
import { ConnectionManager } from '../service/ConnectionManager.service';
import { PhloxAppInfoService } from '../service/PhloxAppInfoService.service';
import { I18N } from '../decorator/I18N.decorator';
const /** @type {?} */ TYPE_NAME = "phx-connection-status-pane";
const /** @type {?} */ STATUS_NORMAL = "Your internet connection is normal.";
const /** @type {?} */ STATUS_SLOW = "Your internet connection is quite slow.";
const /** @type {?} */ STATUS_NOT_CONNECT = "Could not connect to the server.";
const /** @type {?} */ TROUBLESHOOT = "troubleshoot";
export class ConnectionStatusPane {
/**
* @param {?} connectionMgr
* @param {?} phloxAppService
*/
constructor(connectionMgr, phloxAppService) {
this.connectionMgr = connectionMgr;
phloxAppService.getAppInfo().then((result) => {
this.connectionMgr.setPhloxAppInfo(result);
});
this.troubleshoot = TROUBLESHOOT;
}
/**
* @return {?}
*/
getSignalBarClass() {
let /** @type {?} */ signalClasses = [];
this._signalPercent = this.getSignalPercent();
if (this._signalPercent !== null && typeof this._signalPercent === 'number') {
if (this._signalPercent > 0) {
if (this._signalPercent >= 1 && this._signalPercent <= 25) {
signalClasses.push('signal-half');
this.statasMessage = this.statasMessage ? this.statasMessage : STATUS_SLOW;
}
else if (this._signalPercent >= 26 && this._signalPercent <= 50) {
signalClasses.push('signal-half');
this.statasMessage = this.statasMessage ? this.statasMessage : STATUS_SLOW;
}
else if (this._signalPercent >= 51 && this._signalPercent <= 75) {
signalClasses.push('signal-full');
this.statasMessage = this.statasMessage ? this.statasMessage : STATUS_NORMAL;
}
else {
// over 76%
signalClasses.push('signal-full');
this.statasMessage = this.statasMessage ? this.statasMessage : STATUS_NORMAL;
}
}
else {
// <= 0 do nothing
signalClasses.push('signal-lost');
this.statasMessage = this.statasMessage ? this.statasMessage : STATUS_NOT_CONNECT;
}
}
return signalClasses;
}
/**
* @return {?}
*/
getSignalPercent() {
// return this.connectionMgr.getConnectionQuality();
return 60;
}
/**
* @return {?}
*/
getStatasMessage() {
return this.statasMessage;
}
/**
* @param {?} statasMessage
* @return {?}
*/
setStatasMessage(statasMessage) {
this.statasMessage = statasMessage;
}
/**
* @return {?}
*/
getTroubleshoot() {
return this.troubleshoot;
}
/**
* @param {?} troubleshoot
* @return {?}
*/
setTroubleshoot(troubleshoot) {
this.troubleshoot = troubleshoot;
}
}
ConnectionStatusPane.TYPE_NAME = TYPE_NAME;
ConnectionStatusPane.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: `<div class="connection-status-pane">
<div [attr.class]="'status-left ' + getSignalBarClass().join(' ')"></div>
<div class="status-right">
<div [attr.class]="'status-message ' + getSignalBarClass().join(' ')">{{statasMessage}}</div>
<div class="status-troubleshoot" *ngIf="getSignalPercent()<=50">{{troubleshoot}}</div>
</div>
</div>
`
},] },
];
/** @nocollapse */
ConnectionStatusPane.ctorParameters = () => [
{ type: ConnectionManager, },
{ type: PhloxAppInfoService, },
];
tslib_1.__decorate([
I18N(),
tslib_1.__metadata("design:type", String)
], ConnectionStatusPane.prototype, "statasMessage", void 0);
tslib_1.__decorate([
I18N(),
tslib_1.__metadata("design:type", String)
], ConnectionStatusPane.prototype, "troubleshoot", void 0);
function ConnectionStatusPane_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
ConnectionStatusPane.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
ConnectionStatusPane.ctorParameters;
/** @type {?} */
ConnectionStatusPane.TYPE_NAME;
/** @type {?} */
ConnectionStatusPane.prototype.statasMessage;
/** @type {?} */
ConnectionStatusPane.prototype.troubleshoot;
/** @type {?} */
ConnectionStatusPane.prototype.connectionMgr;
/** @type {?} */
ConnectionStatusPane.prototype.model;
/** @type {?} */
ConnectionStatusPane.prototype._signalPercent;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ConnectionStatusPane.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/ConnectionStatusPane.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, HostListener, ViewChild } from '@angular/core';\nimport { ConnectionManager } from '../service/ConnectionManager.service';\nimport { PhloxAppInfoService } from '../service/PhloxAppInfoService.service';\nimport { I18N } from '../decorator/I18N.decorator';\n\n\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-connection-status-pane\";\n\nconst STATUS_NORMAL: string = \"Your internet connection is normal.\";\nconst STATUS_SLOW: string = \"Your internet connection is quite slow.\";\nconst STATUS_NOT_CONNECT: string = \"Could not connect to the server.\";\nconst TROUBLESHOOT: string = \"troubleshoot\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"connection-status-pane\">\r\n\t<div [attr.class]=\"'status-left ' + getSignalBarClass().join(' ')\"></div>\r\n\t<div class=\"status-right\">\r\n\t\t<div [attr.class]=\"'status-message ' + getSignalBarClass().join(' ')\">{{statasMessage}}</div>\r\n\t\t<div class=\"status-troubleshoot\" *ngIf=\"getSignalPercent()<=50\">{{troubleshoot}}</div>\r\n\t</div>\r\n</div>\r\n`\n})\nexport class ConnectionStatusPane {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  @I18N()\n  public statasMessage: string;\n  @I18N()\n  public troubleshoot: string;\n\n  private connectionMgr: ConnectionManager;\n  private model: any;\n  private _signalPercent: number;\n\n  constructor(connectionMgr: ConnectionManager, phloxAppService: PhloxAppInfoService) {\n    this.connectionMgr = connectionMgr;\n\n    phloxAppService.getAppInfo().then((result: any) => {\n      this.connectionMgr.setPhloxAppInfo(result);\n    });\n\n    this.troubleshoot = TROUBLESHOOT;\n  }\n\n  public getSignalBarClass(): string[] {\n    let signalClasses: string[] = [];\n    this._signalPercent = this.getSignalPercent();\n\n    if (this._signalPercent !== null && typeof this._signalPercent === 'number') {\n      if (this._signalPercent > 0) {\n        if (this._signalPercent >= 1 && this._signalPercent <= 25) {\n          signalClasses.push('signal-half');\n          this.statasMessage = this.statasMessage ? this.statasMessage : STATUS_SLOW;\n        } else if (this._signalPercent >= 26 && this._signalPercent <= 50) {\n          signalClasses.push('signal-half');\n          this.statasMessage = this.statasMessage ? this.statasMessage : STATUS_SLOW;\n        } else if (this._signalPercent >= 51 && this._signalPercent <= 75) {\n          signalClasses.push('signal-full');\n          this.statasMessage = this.statasMessage ? this.statasMessage : STATUS_NORMAL;\n        } else {\n          // over 76%\n          signalClasses.push('signal-full');\n          this.statasMessage = this.statasMessage ? this.statasMessage : STATUS_NORMAL;\n        }\n      } else {\n        // <= 0 do nothing\n        signalClasses.push('signal-lost');\n        this.statasMessage = this.statasMessage ? this.statasMessage : STATUS_NOT_CONNECT;\n      }\n    }\n\n    return signalClasses;\n  }\n\n  public getSignalPercent(): number{\n    // return this.connectionMgr.getConnectionQuality();\n    return 60;\n  }\n\n  public getStatasMessage(): string {\n    return this.statasMessage;\n  }\n\n  public setStatasMessage(statasMessage: string): void {\n    this.statasMessage = statasMessage;\n  }\n\n  public getTroubleshoot(): string {\n    return this.troubleshoot;\n  }\n\n  public setTroubleshoot(troubleshoot: string): void {\n    this.troubleshoot = troubleshoot;\n  }\n}\n"]}