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