com.phloxui
Version:
PhloxUI Ng2+ Framework
252 lines (251 loc) • 23.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import { Component, Input, ElementRef, ViewChild } from '@angular/core';
import { ConnectionManager } from '../service/ConnectionManager.service';
import { PhloxAppInfoService } from '../service/PhloxAppInfoService.service';
import { ComponentPopover } from './ComponentPopover.component';
import { ComponentPopoverModel } from './model/ComponentPopoverModel';
import { ConnectionStatusPane } from './ConnectionStatusPane.component';
const /** @type {?} */ TYPE_NAME = "phx-connection-status";
const /** @type {?} */ TOP = 'top';
const /** @type {?} */ BOTTOM = 'bottom';
const /** @type {?} */ LEFT = 'left';
const /** @type {?} */ RIGHT = 'right';
export class ConnectionStatus {
/**
* @param {?} connectionMgr
* @param {?} phloxAppService
* @param {?} elementRef
*/
constructor(connectionMgr, phloxAppService, elementRef) {
this.connectionMgr = connectionMgr;
this.elementRef = elementRef;
phloxAppService.getAppInfo().then((result) => {
this.connectionMgr.setPhloxAppInfo(result);
});
this.arrowPosition = LEFT; // set as default
this.popoverModel = new ComponentPopoverModel(ConnectionStatusPane, this.connectionPaneModel, 0, 0, '220pt', null, null, ['connectionStatus']);
}
/**
* @return {?}
*/
ngOnInit() {
let /** @type {?} */ percent = this.connectionMgr.getConnectionQuality();
this.setArrowPosition(this.popoverPosition);
this.updatePosition();
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
if (changes['popoverPosition'] !== null && typeof changes['popoverPosition'] !== 'undefined') {
let /** @type {?} */ oldVal = changes['popoverPosition'].previousValue;
let /** @type {?} */ newVal = changes['popoverPosition'].currentValue;
if (oldVal !== newVal) {
this.setArrowPosition(this.popoverPosition);
this.updatePosition();
}
}
}
/**
* @param {?} popoverPosition
* @return {?}
*/
setArrowPosition(popoverPosition) {
if (popoverPosition !== null && typeof popoverPosition !== 'undefined') {
if (popoverPosition === TOP) {
// arrow as bottom
this.arrowPosition = BOTTOM;
}
else if (popoverPosition === BOTTOM) {
// arrow as top
this.arrowPosition = TOP;
}
else if (popoverPosition === LEFT) {
// arrow as right
this.arrowPosition = RIGHT;
}
else {
// default as right so arrow as left
this.arrowPosition = LEFT;
}
}
else {
// default as right so arrow as left
this.arrowPosition = LEFT;
}
}
/**
* @return {?}
*/
updatePosition() {
let /** @type {?} */ left = 0;
let /** @type {?} */ top = 0;
let /** @type {?} */ width = 0;
let /** @type {?} */ height = 0;
this.popoverModel.popoverWidth = this.popoverWidth;
this.popoverModel.popoverHeight = this.popoverHeight;
this.popoverModel.showArrow = this.showArrow;
if (this.elementRef !== null && typeof this.elementRef !== 'undefined') {
if (typeof $(this.elementRef.nativeElement) !== 'undefined') {
if (typeof $(this.elementRef.nativeElement).offset() !== 'undefined') {
left = $(this.elementRef.nativeElement).offset().left;
top = $(this.elementRef.nativeElement).offset().top;
width = $(this.elementRef.nativeElement).outerWidth();
height = $(this.elementRef.nativeElement).outerHeight();
}
}
}
if (this.arrowPosition === LEFT || this.arrowPosition === RIGHT) {
this.popoverModel.top = top;
this.popoverModel.left = (left + width) + 10; // 10 as a padding
}
else {
this.popoverModel.top = (top + height) + 10;
this.popoverModel.left = left + width;
}
}
/**
* @param {?} $event
* @return {?}
*/
onBtnClicked($event) {
$event.stopPropagation();
if (this.popover !== null && typeof this.popover !== 'undefined') {
if (this.popover.isShow()) {
this.popover.hide();
}
else {
this.updatePosition();
this.popover.show();
}
}
}
/**
* @param {?} event
* @return {?}
*/
onFocus(event) {
}
/**
* @param {?} event
* @return {?}
*/
onLostFocus(event) {
// do close popover
if (this.popover !== null && typeof this.popover !== 'undefined') {
this.popover.hide();
}
}
/**
* @return {?}
*/
getStatusPercent() {
if (this.connectionMgr !== null && typeof this.connectionMgr !== 'undefined') {
return this.connectionMgr.getConnectionQuality();
}
return 0;
}
/**
* @return {?}
*/
isShowSignal() {
let /** @type {?} */ percent = this.getStatusPercent();
if (percent !== null && typeof percent === 'number') {
if (percent > 0) {
return true;
}
}
return false;
}
/**
* @return {?}
*/
getPopoverModel() {
return this.popoverModel;
}
/**
* @return {?}
*/
getArrowPosition() {
return this.arrowPosition;
}
}
ConnectionStatus.TYPE_NAME = TYPE_NAME;
ConnectionStatus.LEFT = LEFT;
ConnectionStatus.RIGHT = RIGHT;
ConnectionStatus.TOP = TOP;
ConnectionStatus.BOTTOM = BOTTOM;
ConnectionStatus.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: `<div class="phx-connection-status">
<div class="wrapper" (click)="onBtnClicked($event)">
<phx-signals-indicator [percent]="getStatusPercent()"></phx-signals-indicator>
<div class="status status-one-bar" *ngIf="getStatusPercent() <= 25 && getStatusPercent() >= 1"></div>
<div class="status status-zero-bar" *ngIf="getStatusPercent() === 0"></div>
</div>
<phx-component-popover #popover [model]="getPopoverModel()" [position]="getArrowPosition()" [anchor]="'.phx-signals-indicator'"></phx-component-popover>
</div>
`
},] },
];
/** @nocollapse */
ConnectionStatus.ctorParameters = () => [
{ type: ConnectionManager, },
{ type: PhloxAppInfoService, },
{ type: ElementRef, },
];
ConnectionStatus.propDecorators = {
"popoverPosition": [{ type: Input },],
"popoverWidth": [{ type: Input },],
"popoverHeight": [{ type: Input },],
"showArrow": [{ type: Input },],
"popover": [{ type: ViewChild, args: ['popover',] },],
};
function ConnectionStatus_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
ConnectionStatus.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
ConnectionStatus.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
ConnectionStatus.propDecorators;
/** @type {?} */
ConnectionStatus.TYPE_NAME;
/** @type {?} */
ConnectionStatus.LEFT;
/** @type {?} */
ConnectionStatus.RIGHT;
/** @type {?} */
ConnectionStatus.TOP;
/** @type {?} */
ConnectionStatus.BOTTOM;
/** @type {?} */
ConnectionStatus.prototype.popoverPosition;
/** @type {?} */
ConnectionStatus.prototype.popoverWidth;
/** @type {?} */
ConnectionStatus.prototype.popoverHeight;
/** @type {?} */
ConnectionStatus.prototype.showArrow;
/** @type {?} */
ConnectionStatus.prototype.popover;
/** @type {?} */
ConnectionStatus.prototype.connectionMgr;
/** @type {?} */
ConnectionStatus.prototype.popoverModel;
/** @type {?} */
ConnectionStatus.prototype.connectionPaneModel;
/** @type {?} */
ConnectionStatus.prototype.elementRef;
/** @type {?} */
ConnectionStatus.prototype.arrowPosition;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ConnectionStatus.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/ConnectionStatus.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, HostListener, ElementRef, ViewChild } from '@angular/core';\n\nimport { ConnectionManager } from '../service/ConnectionManager.service';\nimport { PhloxAppInfoService } from '../service/PhloxAppInfoService.service';\nimport { ComponentPopover } from './ComponentPopover.component';\nimport { INeedFocus } from './INeedFocus';\nimport { ComponentPopoverModel } from './model/ComponentPopoverModel';\nimport { ConnectionStatusPane } from './ConnectionStatusPane.component';\nimport { Option } from '../decorator/Option.decorator';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-connection-status\";\n\nconst TOP: string = 'top';\nconst BOTTOM: string = 'bottom';\nconst LEFT: string = 'left';\nconst RIGHT: string = 'right';\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-connection-status\">\n\t<div class=\"wrapper\" (click)=\"onBtnClicked($event)\">\n\t\t<phx-signals-indicator [percent]=\"getStatusPercent()\"></phx-signals-indicator>\n\t\t<div class=\"status status-one-bar\" *ngIf=\"getStatusPercent() <= 25 && getStatusPercent() >= 1\"></div>\n\t\t<div class=\"status status-zero-bar\" *ngIf=\"getStatusPercent() === 0\"></div>\n\t</div>\n\t<phx-component-popover #popover [model]=\"getPopoverModel()\" [position]=\"getArrowPosition()\" [anchor]=\"'.phx-signals-indicator'\"></phx-component-popover>\n</div>\n`\n})\nexport class ConnectionStatus implements INeedFocus {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  public static readonly LEFT: string = LEFT;\n  public static readonly RIGHT: string = RIGHT;\n  public static readonly TOP: string = TOP;\n  public static readonly BOTTOM: string = BOTTOM;\n\n  @Input()\n  private popoverPosition: string;\n  @Input()\n  public popoverWidth: string;\n  @Input()\n  public popoverHeight: string;\n  @Input()\n  public showArrow: boolean;\n\n  @ViewChild('popover')\n  private popover: ComponentPopover;\n  private connectionMgr: ConnectionManager;\n  private popoverModel: ComponentPopoverModel;\n  private connectionPaneModel: any;\n  private elementRef: ElementRef;\n  private arrowPosition: string;\n\n  constructor(connectionMgr: ConnectionManager, phloxAppService: PhloxAppInfoService, elementRef: ElementRef) {\n    this.connectionMgr = connectionMgr;\n    this.elementRef = elementRef;\n    phloxAppService.getAppInfo().then((result: any) => {\n      this.connectionMgr.setPhloxAppInfo(result);\n    });\n    this.arrowPosition = LEFT; // set as default\n\n    this.popoverModel = new ComponentPopoverModel(ConnectionStatusPane, this.connectionPaneModel, 0, 0, '220pt', null, null, ['connectionStatus']);\n  }\n\n  public ngOnInit() {\n\n    let percent = this.connectionMgr.getConnectionQuality();\n\n    this.setArrowPosition(this.popoverPosition);\n    this.updatePosition();\n  }\n\n  public ngOnChanges(changes: any) {\n\n    if (changes['popoverPosition'] !== null && typeof changes['popoverPosition'] !== 'undefined') {\n      let oldVal = changes['popoverPosition'].previousValue;\n      let newVal = changes['popoverPosition'].currentValue;\n\n      if (oldVal !== newVal) {\n        this.setArrowPosition(this.popoverPosition);\n        this.updatePosition();\n      }\n    }\n  }\n\n  private setArrowPosition(popoverPosition: string): void {\n    if (popoverPosition !== null && typeof popoverPosition !== 'undefined') {\n      if (popoverPosition === TOP) {\n        // arrow as bottom\n        this.arrowPosition = BOTTOM;\n      } else if (popoverPosition === BOTTOM) {\n        // arrow as top\n        this.arrowPosition = TOP;\n      } else if (popoverPosition === LEFT) {\n        // arrow as right\n        this.arrowPosition = RIGHT;\n      } else {\n        // default as right so arrow as left\n        this.arrowPosition = LEFT;\n      }\n    } else {\n      // default as right so arrow as left\n      this.arrowPosition = LEFT;\n    }\n  }\n\n  private updatePosition(): void {\n    let left: number = 0;\n    let top: number = 0;\n    let width: number = 0;\n    let height: number = 0;\n\n    this.popoverModel.popoverWidth = this.popoverWidth;\n    this.popoverModel.popoverHeight = this.popoverHeight;\n    this.popoverModel.showArrow = this.showArrow;\n\n    if (this.elementRef !== null && typeof this.elementRef !== 'undefined') {\n      if (typeof $(this.elementRef.nativeElement) !== 'undefined') {\n\n        if (typeof $(this.elementRef.nativeElement).offset() !== 'undefined') {\n          left = $(this.elementRef.nativeElement).offset().left;\n          top = $(this.elementRef.nativeElement).offset().top;\n\n          width = $(this.elementRef.nativeElement).outerWidth();\n          height = $(this.elementRef.nativeElement).outerHeight();\n        }\n      }\n    }\n\n    if (this.arrowPosition === LEFT || this.arrowPosition === RIGHT) {\n      this.popoverModel.top = top;\n      this.popoverModel.left = (left + width) + 10; // 10 as a padding\n    } else {\n      this.popoverModel.top = (top + height) + 10;\n      this.popoverModel.left = left + width;\n    }\n  }\n\n  public onBtnClicked($event: Event): void {\n    $event.stopPropagation();\n\n    if (this.popover !== null && typeof this.popover !== 'undefined') {\n      if (this.popover.isShow()) {\n        this.popover.hide();\n      } else {\n        this.updatePosition();\n        this.popover.show();\n      }\n    }\n  }\n\n  public onFocus(event: any): void {\n  }\n\n  public onLostFocus(event: any): void {\n    // do close popover\n    if (this.popover !== null && typeof this.popover !== 'undefined') {\n      this.popover.hide();\n    }\n  }\n\n  public getStatusPercent(): number {\n    if (this.connectionMgr !== null && typeof this.connectionMgr !== 'undefined') {\n      return this.connectionMgr.getConnectionQuality();\n    }\n    return 0;\n  }\n\n  public isShowSignal(): boolean {\n    let percent = this.getStatusPercent();\n\n    if (percent !== null && typeof percent === 'number') {\n      if (percent > 0) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  public getPopoverModel(): ComponentPopoverModel {\n    return this.popoverModel;\n  }\n\n  public getArrowPosition(): string {\n    return this.arrowPosition;\n  }\n}\n"]}