com.phloxui
Version:
PhloxUI Ng2+ Framework
189 lines (188 loc) • 13.9 kB
JavaScript
/**
* @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"]}