com.phloxui
Version:
PhloxUI Ng2+ Framework
228 lines (227 loc) • 15.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
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';
var /** @type {?} */ TYPE_NAME = "phx-app-switcher";
var /** @type {?} */ SUB_TOPIC_NAME = 'app-switcher';
var PhloxAppSwitcher = /** @class */ (function (_super) {
tslib_1.__extends(PhloxAppSwitcher, _super);
function PhloxAppSwitcher(appSvc, needFocusService) {
var _this = _super.call(this, appSvc, needFocusService) || this;
_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 _this;
}
/**
* @return {?}
*/
PhloxAppSwitcher.prototype.ngOnInit = /**
* @return {?}
*/
function () {
//super.ngOnInit();
this.contentText = '<div class="anchor"></div>';
this.appPopoverType = AppDrawerPopover;
this.subTopicName = PhloxAppSwitcher.SUB_TOPIC_NAME;
};
/**
* @param {?} $event
* @return {?}
*/
PhloxAppSwitcher.prototype.doFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
};
/**
* @param {?} $event
* @return {?}
*/
PhloxAppSwitcher.prototype.doLostFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
};
/**
* @param {?} $event
* @return {?}
*/
PhloxAppSwitcher.prototype.onPopoverBtnClicked = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
$event.stopPropagation();
};
/**
* @param {?} $event
* @return {?}
*/
PhloxAppSwitcher.prototype.onPopoverActived = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
this.source = $event.source;
this.needFocusService.setFocusingComponent(this);
};
/**
* @param {?} $event
* @return {?}
*/
PhloxAppSwitcher.prototype.onPopoverInactived = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
this.source = null;
this.needFocusService.resetFocusingComponent();
};
/**
* @param {?} event
* @return {?}
*/
PhloxAppSwitcher.prototype.onClick = /**
* @param {?} event
* @return {?}
*/
function (event) {
_super.prototype.onClick.call(this, event);
};
/**
* @param {?} event
* @return {?}
*/
PhloxAppSwitcher.prototype.onFocus = /**
* @param {?} event
* @return {?}
*/
function (event) {
};
/**
* @param {?} event
* @return {?}
*/
PhloxAppSwitcher.prototype.onLostFocus = /**
* @param {?} event
* @return {?}
*/
function (event) {
if (this.source != null) {
this.source.hide();
}
};
/**
* @param {?} $event
* @return {?}
*/
PhloxAppSwitcher.prototype._onDocumentClick = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
$event.stopPropagation();
if (this.source != null) {
this.source.hide();
}
};
/**
* @return {?}
*/
PhloxAppSwitcher.prototype.getContentText = /**
* @return {?}
*/
function () {
return this.contentText;
};
/**
* @return {?}
*/
PhloxAppSwitcher.prototype.getSubTopicName = /**
* @return {?}
*/
function () {
return this.subTopicName;
};
/**
* @return {?}
*/
PhloxAppSwitcher.prototype.getAppPopoverType = /**
* @return {?}
*/
function () {
return this.appPopoverType;
};
/**
* @return {?}
*/
PhloxAppSwitcher.prototype.getDelay = /**
* @return {?}
*/
function () {
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()\"\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",
entryComponents: [AppDrawerPopover],
// add to resolve factory
host: {
'(document:click)': '_onDocumentClick($event)'
}
},] },
];
/** @nocollapse */
PhloxAppSwitcher.ctorParameters = function () { return [
{ type: PhloxAppService, },
{ type: NeedFocusService, },
]; };
PhloxAppSwitcher.propDecorators = {
"onClick": [{ type: HostListener, args: ['click', ['$event'],] },],
};
return PhloxAppSwitcher;
}(AbstractRippleButton));
export { PhloxAppSwitcher };
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"]}