com.phloxui
Version:
PhloxUI Ng2+ Framework
157 lines (156 loc) • 14 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';
var /** @type {?} */ TYPE_NAME = "phx-connection-status-pane";
var /** @type {?} */ STATUS_NORMAL = "Your internet connection is normal.";
var /** @type {?} */ STATUS_SLOW = "Your internet connection is quite slow.";
var /** @type {?} */ STATUS_NOT_CONNECT = "Could not connect to the server.";
var /** @type {?} */ TROUBLESHOOT = "troubleshoot";
var ConnectionStatusPane = /** @class */ (function () {
function ConnectionStatusPane(connectionMgr, phloxAppService) {
var _this = this;
this.connectionMgr = connectionMgr;
phloxAppService.getAppInfo().then(function (result) {
_this.connectionMgr.setPhloxAppInfo(result);
});
this.troubleshoot = TROUBLESHOOT;
}
/**
* @return {?}
*/
ConnectionStatusPane.prototype.getSignalBarClass = /**
* @return {?}
*/
function () {
var /** @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 {?}
*/
ConnectionStatusPane.prototype.getSignalPercent = /**
* @return {?}
*/
function () {
// return this.connectionMgr.getConnectionQuality();
return 60;
};
/**
* @return {?}
*/
ConnectionStatusPane.prototype.getStatasMessage = /**
* @return {?}
*/
function () {
return this.statasMessage;
};
/**
* @param {?} statasMessage
* @return {?}
*/
ConnectionStatusPane.prototype.setStatasMessage = /**
* @param {?} statasMessage
* @return {?}
*/
function (statasMessage) {
this.statasMessage = statasMessage;
};
/**
* @return {?}
*/
ConnectionStatusPane.prototype.getTroubleshoot = /**
* @return {?}
*/
function () {
return this.troubleshoot;
};
/**
* @param {?} troubleshoot
* @return {?}
*/
ConnectionStatusPane.prototype.setTroubleshoot = /**
* @param {?} troubleshoot
* @return {?}
*/
function (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\">\n\t<div [attr.class]=\"'status-left ' + getSignalBarClass().join(' ')\"></div>\n\t<div class=\"status-right\">\n\t\t<div [attr.class]=\"'status-message ' + getSignalBarClass().join(' ')\">{{statasMessage}}</div>\n\t\t<div class=\"status-troubleshoot\" *ngIf=\"getSignalPercent()<=50\">{{troubleshoot}}</div>\n\t</div>\n</div>\n"
},] },
];
/** @nocollapse */
ConnectionStatusPane.ctorParameters = function () { return [
{ 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);
return ConnectionStatusPane;
}());
export { ConnectionStatusPane };
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"]}