UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

228 lines (227 loc) 15.6 kB
/** * @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"]}