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