UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

254 lines (253 loc) 26.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ const /** @type {?} */ SUB_TOPIC_NAME = 'side-slide-panel'; const /** @type {?} */ TOPIC_NAME_PREFIX = 'side-slide-panel.'; const /** @type {?} */ SHOW_SUFFIX = 'show'; const /** @type {?} */ HIDE_SUFFIX = 'hide'; const /** @type {?} */ CMD_SUFFIX = 'cmd'; const /** @type {?} */ SHOW_TOPIC_NAME = TOPIC_NAME_PREFIX + SHOW_SUFFIX; const /** @type {?} */ HIDE_TOPIC_NAME = TOPIC_NAME_PREFIX + HIDE_SUFFIX; const /** @type {?} */ CMD_TOPIC_NAME = TOPIC_NAME_PREFIX + CMD_SUFFIX; /** * <p style="text-indent: 2em;"> * An abstract base class for side slide panel component. This class will automatically publish <code>hide</code> and <code> * show</code> events to [[ObservableManager]] on topic name <code>side-slide-panel.[sub-topic-name].show</code> and <code> * side-slide-panel.[sub-topic-name].hide</code> respectively. You can also control the show/hide state of this component * via [[ObservableManager]] by publishing <code>boolean</code> to <code>side-slide-panel.[sub-topic-name].cmd</code> topic. * This class provides the default implementation for method [[onLostFocus]] to automatically hide this component when focus lost. * </p> * * @author shiorin, tee4cute * @see [[ObservableManager]] * @see [[INeedFocus]] * @abstract */ export class AbstractSideSlidePanel { /** * @param {?} phloxAppService * @param {?} observableMgr * @param {?} needFocusService * @param {?} subTopicName */ constructor(phloxAppService, observableMgr, needFocusService, subTopicName) { if (phloxAppService !== null && typeof phloxAppService !== 'undefined') { this.phloxAppService = phloxAppService; } this.observableMgr = observableMgr; this.needFocusService = needFocusService; this.active = false; this.subTopicName = subTopicName; this.showSubjects = []; this.hideSubjects = []; } /** * @param {?} subTopicName * @return {?} */ static getShowTopicName(subTopicName) { if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') { return AbstractSideSlidePanel.SHOW_TOPIC_NAME; } if (subTopicName.charAt(0) === '.') { subTopicName = subTopicName.substring(1); } if (subTopicName === '') { return AbstractSideSlidePanel.SHOW_TOPIC_NAME; } if (subTopicName.charAt(subTopicName.length - 1) !== '.') { subTopicName += '.'; } return TOPIC_NAME_PREFIX + subTopicName + SHOW_SUFFIX; } /** * @param {?} subTopicName * @return {?} */ static getHideTopicName(subTopicName) { if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') { return AbstractSideSlidePanel.HIDE_TOPIC_NAME; } if (subTopicName.charAt(0) === '.') { subTopicName = subTopicName.substring(1); } if (subTopicName === '') { return AbstractSideSlidePanel.HIDE_TOPIC_NAME; } if (subTopicName.charAt(subTopicName.length - 1) !== '.') { subTopicName += '.'; } return TOPIC_NAME_PREFIX + subTopicName + HIDE_SUFFIX; } /** * @param {?} subTopicName * @return {?} */ static getCmdTopicName(subTopicName) { if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') { return AbstractSideSlidePanel.CMD_TOPIC_NAME; } if (subTopicName.charAt(0) === '.') { subTopicName = subTopicName.substring(1); } if (subTopicName === '') { return AbstractSideSlidePanel.CMD_TOPIC_NAME; } if (subTopicName.charAt(subTopicName.length - 1) !== '.') { subTopicName += '.'; } return TOPIC_NAME_PREFIX + subTopicName + CMD_SUFFIX; } /** * @return {?} */ get app() { if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') { return null; } return this.phloxAppService.getInstance(); } /** * @param {?} showTopic * @param {?} hideTopic * @param {?} showCmdTopic * @return {?} */ initSideSlideEventTopics(showTopic, hideTopic, showCmdTopic) { // Create change event observable topics if (showTopic !== null && typeof showTopic === 'string') { this.showSubjects.push(this.observableMgr.createSubject(showTopic)); } if (hideTopic !== null && typeof hideTopic === 'string') { this.hideSubjects.push(this.observableMgr.createSubject(hideTopic)); } // Subscribe on CMD topics if (showCmdTopic !== null && typeof showCmdTopic === 'string') { this.observableMgr.subscribe(showCmdTopic, (show) => { if (typeof show === 'boolean') { this.active = show; } }); } } /** * @return {?} */ ngOnInit() { // Init super class event topics this.initSideSlideEventTopics(AbstractSideSlidePanel.SHOW_TOPIC_NAME, AbstractSideSlidePanel.HIDE_TOPIC_NAME, AbstractSideSlidePanel.CMD_TOPIC_NAME); if (this.subTopicName !== null && this.subTopicName !== '' || typeof this.subTopicName !== 'undefined') { // Init sub topic event topics this.initSideSlideEventTopics(AbstractSideSlidePanel.getShowTopicName(this.subTopicName), AbstractSideSlidePanel.getHideTopicName(this.subTopicName), AbstractSideSlidePanel.getCmdTopicName(this.subTopicName)); } } /** * @return {?} */ getApplication() { return this.app; } /** * <p style="text-indent: 1em;"> * Show this component. This method also publishes an event to topic <code>side-slide-panel.[sub-topic-name].show</code>. * </p> * @return {?} */ show() { this.active = true; if (Array.isArray(this.showSubjects)) { // Emit change event this.showSubjects.forEach((obsv, idx) => { obsv.next(this); }); } } /** * <p style="text-indent: 1em;"> * Hide this component. This method also publishes an event to topic <code>side-slide-panel.[sub-topic-name].hide</code>. * </p> * @return {?} */ hide() { this.active = false; if (Array.isArray(this.hideSubjects)) { // Emit change event this.hideSubjects.forEach((obsv, idx) => { obsv.next(this); }); } } /** * <p style="text-indent: 1em;"> * Toggle show/hide this component. This method also publishes an event to topic <code>side-slide-panel.[sub-topic-name].show</code> * and <code>side-slide-panel.[sub-topic-name].hide</code> when the component is shown or hidden respectively. * </p> * @param {?} event * @return {?} */ onToggle(event) { if (this.active) { this.hide(); this.needFocusService.resetFocusingComponent(); } else { this.show(); this.needFocusService.setFocusingComponent(this); } } /** * @param {?} event * @return {?} */ onFocus(event) { } /** * @param {?} event * @return {?} */ onLostFocus(event) { this.hide(); } /** * @return {?} */ isActive() { return this.active; } /** * @return {?} */ getSubTopicName() { return this.subTopicName; } } AbstractSideSlidePanel.SUB_TOPIC_NAME = SUB_TOPIC_NAME; AbstractSideSlidePanel.SHOW_TOPIC_NAME = SHOW_TOPIC_NAME; AbstractSideSlidePanel.HIDE_TOPIC_NAME = HIDE_TOPIC_NAME; AbstractSideSlidePanel.CMD_TOPIC_NAME = CMD_TOPIC_NAME; function AbstractSideSlidePanel_tsickle_Closure_declarations() { /** @type {?} */ AbstractSideSlidePanel.SUB_TOPIC_NAME; /** @type {?} */ AbstractSideSlidePanel.SHOW_TOPIC_NAME; /** @type {?} */ AbstractSideSlidePanel.HIDE_TOPIC_NAME; /** @type {?} */ AbstractSideSlidePanel.CMD_TOPIC_NAME; /** @type {?} */ AbstractSideSlidePanel.prototype.phloxAppService; /** @type {?} */ AbstractSideSlidePanel.prototype.observableMgr; /** @type {?} */ AbstractSideSlidePanel.prototype.needFocusService; /** @type {?} */ AbstractSideSlidePanel.prototype.active; /** @type {?} */ AbstractSideSlidePanel.prototype.subTopicName; /** @type {?} */ AbstractSideSlidePanel.prototype.showSubjects; /** @type {?} */ AbstractSideSlidePanel.prototype.hideSubjects; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractSideSlidePanel.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/AbstractSideSlidePanel.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { Subject } from 'rxjs/Subject';\n\nimport { PhloxApp } from './PhloxApp.component';\nimport { IApplicationAware } from './IApplicationAware';\nimport { ObservableManager, PhloxAppService, NeedFocusService } from '../service/services';\nimport { INeedFocus } from '../component/components';\n\nconst SUB_TOPIC_NAME: string = 'side-slide-panel';\nconst TOPIC_NAME_PREFIX: string = 'side-slide-panel.';\nconst SHOW_SUFFIX: string = 'show';\nconst HIDE_SUFFIX: string = 'hide';\nconst CMD_SUFFIX: string = 'cmd';\nconst SHOW_TOPIC_NAME: string = TOPIC_NAME_PREFIX + SHOW_SUFFIX;\nconst HIDE_TOPIC_NAME: string = TOPIC_NAME_PREFIX + HIDE_SUFFIX;\nconst CMD_TOPIC_NAME: string = TOPIC_NAME_PREFIX + CMD_SUFFIX;\n\n/**\n * <p style=\"text-indent: 2em;\">\n * An abstract base class for side slide panel component. This class will automatically publish <code>hide</code> and <code>\n * show</code> events to [[ObservableManager]] on topic name <code>side-slide-panel.[sub-topic-name].show</code> and <code>\n * side-slide-panel.[sub-topic-name].hide</code> respectively. You can also control the show/hide state of this component\n * via [[ObservableManager]] by publishing <code>boolean</code> to <code>side-slide-panel.[sub-topic-name].cmd</code> topic.\n * This class provides the default implementation for method [[onLostFocus]] to automatically hide this component when focus lost.\n * </p>\n *\n * @author shiorin, tee4cute\n * @see [[ObservableManager]]\n * @see [[INeedFocus]]\n */\nexport abstract class AbstractSideSlidePanel implements IApplicationAware, OnInit, INeedFocus {\n\n    public static readonly SUB_TOPIC_NAME: string = SUB_TOPIC_NAME;\n    public static readonly SHOW_TOPIC_NAME: string = SHOW_TOPIC_NAME;\n    public static readonly HIDE_TOPIC_NAME: string = HIDE_TOPIC_NAME;\n    public static readonly CMD_TOPIC_NAME: string = CMD_TOPIC_NAME;\n\n    public static getShowTopicName(subTopicName: string): string {\n        if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') {\n            return AbstractSideSlidePanel.SHOW_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(0) === '.') {\n            subTopicName = subTopicName.substring(1);\n        }\n\n        if (subTopicName === '') {\n            return AbstractSideSlidePanel.SHOW_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(subTopicName.length - 1) !== '.') {\n            subTopicName += '.';\n        }\n\n        return TOPIC_NAME_PREFIX + subTopicName + SHOW_SUFFIX;\n    }\n\n    public static getHideTopicName(subTopicName: string): string {\n        if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') {\n            return AbstractSideSlidePanel.HIDE_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(0) === '.') {\n            subTopicName = subTopicName.substring(1);\n        }\n\n        if (subTopicName === '') {\n            return AbstractSideSlidePanel.HIDE_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(subTopicName.length - 1) !== '.') {\n            subTopicName += '.';\n        }\n\n        return TOPIC_NAME_PREFIX + subTopicName + HIDE_SUFFIX;\n    }\n\n    public static getCmdTopicName(subTopicName: string): string {\n        if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') {\n            return AbstractSideSlidePanel.CMD_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(0) === '.') {\n            subTopicName = subTopicName.substring(1);\n        }\n\n        if (subTopicName === '') {\n            return AbstractSideSlidePanel.CMD_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(subTopicName.length - 1) !== '.') {\n            subTopicName += '.';\n        }\n\n        return TOPIC_NAME_PREFIX + subTopicName + CMD_SUFFIX;\n    }\n\n    protected phloxAppService: PhloxAppService;\n    protected observableMgr: ObservableManager;\n    protected needFocusService: NeedFocusService;\n    protected active: boolean;\n    protected subTopicName: string;\n    protected showSubjects: Subject<any>[];\n    protected hideSubjects: Subject<any>[];\n\n    private get app(): PhloxApp {\n        if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') {\n            return null;\n        }\n        return this.phloxAppService.getInstance();\n    }\n\n    constructor(phloxAppService: PhloxAppService, observableMgr: ObservableManager, needFocusService: NeedFocusService, subTopicName: string) {\n        if (phloxAppService !== null && typeof phloxAppService !== 'undefined') {\n            this.phloxAppService = phloxAppService;\n        }\n        this.observableMgr = observableMgr;\n        this.needFocusService = needFocusService;\n        this.active = false;\n        this.subTopicName = subTopicName;\n        this.showSubjects = [];\n        this.hideSubjects = [];\n    }\n\n    private initSideSlideEventTopics(showTopic: string, hideTopic: string, showCmdTopic: string): void {\n        // Create change event observable topics\n        if (showTopic !== null && typeof showTopic === 'string') {\n          this.showSubjects.push(this.observableMgr.createSubject(showTopic));\n        }\n        if (hideTopic !== null && typeof hideTopic === 'string') {\n          this.hideSubjects.push(this.observableMgr.createSubject(hideTopic));\n        }\n\n        // Subscribe on CMD topics\n        if (showCmdTopic !== null && typeof showCmdTopic === 'string') {\n          this.observableMgr.subscribe(showCmdTopic, (show: any) => {\n              if (typeof show === 'boolean') {\n                  this.active = show;\n              }\n          });\n        }\n    }\n\n    public ngOnInit(): void {\n        // Init super class event topics\n        this.initSideSlideEventTopics(\n            AbstractSideSlidePanel.SHOW_TOPIC_NAME,\n            AbstractSideSlidePanel.HIDE_TOPIC_NAME,\n            AbstractSideSlidePanel.CMD_TOPIC_NAME\n        );\n\n        if (this.subTopicName !== null && this.subTopicName !== '' || typeof this.subTopicName !== 'undefined') {\n            // Init sub topic event topics\n            this.initSideSlideEventTopics(\n                AbstractSideSlidePanel.getShowTopicName(this.subTopicName),\n                AbstractSideSlidePanel.getHideTopicName(this.subTopicName),\n                AbstractSideSlidePanel.getCmdTopicName(this.subTopicName)\n            );\n        }\n    }\n\n    public getApplication(): PhloxApp {\n        return this.app;\n    }\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Show this component. This method also publishes an event to topic <code>side-slide-panel.[sub-topic-name].show</code>.\n     * </p>\n     */\n    public show(): void {\n        this.active = true;\n\n        if (Array.isArray(this.showSubjects)) {\n            // Emit change event\n            this.showSubjects.forEach((obsv, idx) => {\n                obsv.next(this);\n            });\n        }\n    }\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Hide this component. This method also publishes an event to topic <code>side-slide-panel.[sub-topic-name].hide</code>.\n     * </p>\n     */\n    public hide(): void {\n        this.active = false;\n\n        if (Array.isArray(this.hideSubjects)) {\n            // Emit change event\n            this.hideSubjects.forEach((obsv, idx) => {\n                obsv.next(this);\n            });\n        }\n    }\n\n    /**\n     * <p style=\"text-indent: 1em;\">\n     * Toggle show/hide this component.  This method also publishes an event to topic <code>side-slide-panel.[sub-topic-name].show</code>\n     * and <code>side-slide-panel.[sub-topic-name].hide</code> when the component is shown or hidden respectively.\n     * </p>\n     */\n    public onToggle(event: MouseEvent): void {\n        if (this.active) {\n            this.hide();\n            this.needFocusService.resetFocusingComponent();\n        } else {\n            this.show();\n            this.needFocusService.setFocusingComponent(this);\n        }\n    }\n\n    public onFocus(event: any): void {\n\n    }\n\n    public onLostFocus(event: any): void {\n        this.hide();\n    }\n\n    public isActive(): boolean {\n      return this.active;\n    }\n\n    public getSubTopicName(): string {\n      return this.subTopicName;\n    }\n}\n"]}