UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

315 lines (314 loc) 28.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ var /** @type {?} */ SUB_TOPIC_NAME = 'side-slide-panel'; var /** @type {?} */ TOPIC_NAME_PREFIX = 'side-slide-panel.'; var /** @type {?} */ SHOW_SUFFIX = 'show'; var /** @type {?} */ HIDE_SUFFIX = 'hide'; var /** @type {?} */ CMD_SUFFIX = 'cmd'; var /** @type {?} */ SHOW_TOPIC_NAME = TOPIC_NAME_PREFIX + SHOW_SUFFIX; var /** @type {?} */ HIDE_TOPIC_NAME = TOPIC_NAME_PREFIX + HIDE_SUFFIX; var /** @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 */ var AbstractSideSlidePanel = /** @class */ (function () { function AbstractSideSlidePanel(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 {?} */ AbstractSideSlidePanel.getShowTopicName = /** * @param {?} subTopicName * @return {?} */ function (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 {?} */ AbstractSideSlidePanel.getHideTopicName = /** * @param {?} subTopicName * @return {?} */ function (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 {?} */ AbstractSideSlidePanel.getCmdTopicName = /** * @param {?} subTopicName * @return {?} */ function (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; }; Object.defineProperty(AbstractSideSlidePanel.prototype, "app", { get: /** * @return {?} */ function () { if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') { return null; } return this.phloxAppService.getInstance(); }, enumerable: true, configurable: true }); /** * @param {?} showTopic * @param {?} hideTopic * @param {?} showCmdTopic * @return {?} */ AbstractSideSlidePanel.prototype.initSideSlideEventTopics = /** * @param {?} showTopic * @param {?} hideTopic * @param {?} showCmdTopic * @return {?} */ function (showTopic, hideTopic, showCmdTopic) { var _this = this; // 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, function (show) { if (typeof show === 'boolean') { _this.active = show; } }); } }; /** * @return {?} */ AbstractSideSlidePanel.prototype.ngOnInit = /** * @return {?} */ function () { // 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 {?} */ AbstractSideSlidePanel.prototype.getApplication = /** * @return {?} */ function () { 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 {?} */ AbstractSideSlidePanel.prototype.show = /** * <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 {?} */ function () { var _this = this; this.active = true; if (Array.isArray(this.showSubjects)) { // Emit change event this.showSubjects.forEach(function (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 {?} */ AbstractSideSlidePanel.prototype.hide = /** * <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 {?} */ function () { var _this = this; this.active = false; if (Array.isArray(this.hideSubjects)) { // Emit change event this.hideSubjects.forEach(function (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 {?} */ AbstractSideSlidePanel.prototype.onToggle = /** * <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 {?} */ function (event) { if (this.active) { this.hide(); this.needFocusService.resetFocusingComponent(); } else { this.show(); this.needFocusService.setFocusingComponent(this); } }; /** * @param {?} event * @return {?} */ AbstractSideSlidePanel.prototype.onFocus = /** * @param {?} event * @return {?} */ function (event) { }; /** * @param {?} event * @return {?} */ AbstractSideSlidePanel.prototype.onLostFocus = /** * @param {?} event * @return {?} */ function (event) { this.hide(); }; /** * @return {?} */ AbstractSideSlidePanel.prototype.isActive = /** * @return {?} */ function () { return this.active; }; /** * @return {?} */ AbstractSideSlidePanel.prototype.getSubTopicName = /** * @return {?} */ function () { 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; return AbstractSideSlidePanel; }()); export { AbstractSideSlidePanel }; 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"]}