UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

189 lines (188 loc) 13.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import { Component, HostListener } from '@angular/core'; import { PhloxAppService } from '../../../service/PhloxAppService.service'; import { NeedFocusService } from '../../../service/NeedFocusService.service'; import { AppDrawerPopover } from './switcher.internal/AppDrawerPopover.component'; import { AbstractRippleButton } from '../../AbstractRippleButton'; import { PhloxAppInfo } from '../../../component/model/PhloxAppInfo'; const /** @type {?} */ TYPE_NAME = "phx-app-switcher"; const /** @type {?} */ SUB_TOPIC_NAME = 'app-switcher'; export class PhloxAppSwitcher extends AbstractRippleButton { /** * @param {?} appSvc * @param {?} needFocusService */ constructor(appSvc, needFocusService) { super(appSvc, needFocusService); this.delay = PhloxAppInfo.DEFAULT_APP_SWITCHER_POPOVER_DELAY; if (this.getApplication() !== null && typeof this.getApplication() !== 'undefined' && this.getApplication().getAppInfo() !== null && typeof this.getApplication().getAppInfo() !== 'undefined') { this.delay = this.getApplication().getAppInfo().settings.APP_SWITCHER_POPOVER_DELAY; } } /** * @return {?} */ ngOnInit() { //super.ngOnInit(); this.contentText = '<div class="anchor"></div>'; this.appPopoverType = AppDrawerPopover; this.subTopicName = PhloxAppSwitcher.SUB_TOPIC_NAME; } /** * @param {?} $event * @return {?} */ doFocus($event) { } /** * @param {?} $event * @return {?} */ doLostFocus($event) { } /** * @param {?} $event * @return {?} */ onPopoverBtnClicked($event) { $event.stopPropagation(); } /** * @param {?} $event * @return {?} */ onPopoverActived($event) { this.source = $event.source; this.needFocusService.setFocusingComponent(this); } /** * @param {?} $event * @return {?} */ onPopoverInactived($event) { this.source = null; this.needFocusService.resetFocusingComponent(); } /** * @param {?} event * @return {?} */ onClick(event) { super.onClick(event); } /** * @param {?} event * @return {?} */ onFocus(event) { } /** * @param {?} event * @return {?} */ onLostFocus(event) { if (this.source != null) { this.source.hide(); } } /** * @param {?} $event * @return {?} */ _onDocumentClick($event) { $event.stopPropagation(); if (this.source != null) { this.source.hide(); } } /** * @return {?} */ getContentText() { return this.contentText; } /** * @return {?} */ getSubTopicName() { return this.subTopicName; } /** * @return {?} */ getAppPopoverType() { return this.appPopoverType; } /** * @return {?} */ getDelay() { return this.delay; } } PhloxAppSwitcher.TYPE_NAME = TYPE_NAME; PhloxAppSwitcher.SUB_TOPIC_NAME = SUB_TOPIC_NAME; PhloxAppSwitcher.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: `<div class="phx-app-switcher" [phxPopover]="getContentText()" [component-type]="getAppPopoverType()" [delay]="getDelay()" [topicName]="getSubTopicName()" (phxClick)="onPopoverBtnClicked($event)" (phxActive)="onPopoverActived($event)" (phxInactive)="onPopoverInactived($event)"> <div class="box-container"> <div class="inline-boxes"> <div class="square"></div> <div class="square"></div> </div> <div class="inline-boxes"> <div class="square"></div> <div class="square"></div> </div> </div> </div> `, entryComponents: [AppDrawerPopover], // add to resolve factory host: { '(document:click)': '_onDocumentClick($event)' } },] }, ]; /** @nocollapse */ PhloxAppSwitcher.ctorParameters = () => [ { type: PhloxAppService, }, { type: NeedFocusService, }, ]; PhloxAppSwitcher.propDecorators = { "onClick": [{ type: HostListener, args: ['click', ['$event'],] },], }; function PhloxAppSwitcher_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ PhloxAppSwitcher.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ PhloxAppSwitcher.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ PhloxAppSwitcher.propDecorators; /** @type {?} */ PhloxAppSwitcher.TYPE_NAME; /** @type {?} */ PhloxAppSwitcher.SUB_TOPIC_NAME; /** @type {?} */ PhloxAppSwitcher.prototype.contentText; /** @type {?} */ PhloxAppSwitcher.prototype.subTopicName; /** @type {?} */ PhloxAppSwitcher.prototype.appPopoverType; /** @type {?} */ PhloxAppSwitcher.prototype.delay; /** @type {?} */ PhloxAppSwitcher.prototype.source; } export { AppDrawerPopover } from './switcher.internal/AppDrawerPopover.component'; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PhloxAppSwitcher.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/page/main/PhloxAppSwitcher.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, HostListener, ElementRef, Type } from '@angular/core';\nimport { PhloxApp } from '../../PhloxApp.component';\nimport { INeedFocus } from '../../../component/components';\nimport { PhloxAppService } from '../../../service/PhloxAppService.service';\nimport { NeedFocusService } from '../../../service/NeedFocusService.service';\nimport { AppDrawerPopover } from './switcher.internal/AppDrawerPopover.component';\nimport { AbstractRippleButton } from '../../AbstractRippleButton';\nimport { PhloxAppInfo } from '../../../component/model/PhloxAppInfo';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-app-switcher\";\n\nconst SUB_TOPIC_NAME: string = 'app-switcher';\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-app-switcher\" [phxPopover]=\"getContentText()\" [component-type]=\"getAppPopoverType()\" [delay]=\"getDelay()\" [topicName]=\"getSubTopicName()\"\n\t(phxClick)=\"onPopoverBtnClicked($event)\" (phxActive)=\"onPopoverActived($event)\" (phxInactive)=\"onPopoverInactived($event)\">\n\t<div class=\"box-container\">\n\t\t<div class=\"inline-boxes\">\n\t\t\t<div class=\"square\"></div>\n\t\t\t<div class=\"square\"></div>\n\t\t</div>\n\t\t<div class=\"inline-boxes\">\n\t\t\t<div class=\"square\"></div>\n\t\t\t<div class=\"square\"></div>\n\t\t</div>\n\t</div>\n</div>\n`,\n  entryComponents: [AppDrawerPopover], // add to resolve factory\n  host: {\n    '(document:click)': '_onDocumentClick($event)'\n  }\n})\nexport class PhloxAppSwitcher extends AbstractRippleButton implements OnInit, INeedFocus {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  public static readonly SUB_TOPIC_NAME: string = SUB_TOPIC_NAME;\n\n  // use for app drawer\n  private contentText: string;\n  private subTopicName: string;\n  private appPopoverType: Type<any>;\n  private delay: number;\n  private source: any;\n\n  constructor(appSvc: PhloxAppService, needFocusService: NeedFocusService) {\n    super(appSvc, needFocusService);\n\n    this.delay = PhloxAppInfo.DEFAULT_APP_SWITCHER_POPOVER_DELAY;\n    \n    if (this.getApplication() !== null && typeof this.getApplication() !== 'undefined' &&\n      this.getApplication().getAppInfo() !== null && typeof this.getApplication().getAppInfo() !== 'undefined') {\n      this.delay = this.getApplication().getAppInfo().settings.APP_SWITCHER_POPOVER_DELAY;\n    }\n  }\n\n  public ngOnInit(): void {\n    //super.ngOnInit();\n    this.contentText = '<div class=\"anchor\"></div>';\n    this.appPopoverType = AppDrawerPopover;\n    this.subTopicName = PhloxAppSwitcher.SUB_TOPIC_NAME;\n  }\n\n  protected doFocus($event: Event): void {\n\n  }\n\n  protected doLostFocus($event: Event): void {\n\n  }\n\n  public onPopoverBtnClicked($event: MouseEvent) {\n    $event.stopPropagation();\n  }\n\n  public onPopoverActived($event: any) {\n    this.source = $event.source;\n    this.needFocusService.setFocusingComponent(this);\n  }\n\n  public onPopoverInactived($event: any) {\n    this.source = null;\n    this.needFocusService.resetFocusingComponent();\n  }\n\n  @HostListener('click', ['$event'])\n  public onClick(event: MouseEvent): void {\n    super.onClick(event);\n  }\n\n  public onFocus(event: any): void {\n\n  }\n\n  public onLostFocus(event: any): void {\n    if (this.source != null) {\n      this.source.hide();\n    }\n  }\n\n  public _onDocumentClick($event: any): void {\n    $event.stopPropagation();\n\n    if (this.source != null) {\n      this.source.hide();\n    }\n  }\n\n  public getContentText(): string {\n    return this.contentText;\n  }\n\n  public getSubTopicName(): string {\n    return this.subTopicName;\n  }\n\n  public getAppPopoverType(): Type<any> {\n    return this.appPopoverType;\n  }\n\n  public getDelay(): number {\n    return this.delay;\n  }\n}\n\nexport * from './switcher.internal/AppDrawerPopover.component';\n"]}