UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

252 lines (251 loc) 23.4 kB
/** * @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"]}