com.phloxui
Version:
PhloxUI Ng2+ Framework
307 lines (306 loc) • 33.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import { AbstractNavMenu } from './AbstractNavMenu';
const /** @type {?} */ SUB_TOPIC_NAME = 'nav-left-layout';
const /** @type {?} */ TOPIC_NAME_PREFIX = 'nav-left-layout.';
const /** @type {?} */ FIXED_CHANGE_SUFFIX = 'fixed';
const /** @type {?} */ TOGGLED_CHANGE_SUFFIX = 'toggled';
const /** @type {?} */ FIXED_CMD_SUFFIX = 'cmd.fixed';
const /** @type {?} */ TOGGLED_CMD_SUFFIX = 'cmd.toggled';
const /** @type {?} */ FIXED_CHANGE_TOPIC_NAME = TOPIC_NAME_PREFIX + FIXED_CHANGE_SUFFIX;
const /** @type {?} */ TOGGLED_CHANGE_TOPIC_NAME = TOPIC_NAME_PREFIX + TOGGLED_CHANGE_SUFFIX;
const /** @type {?} */ FIXED_CMD_TOPIC_NAME = TOPIC_NAME_PREFIX + FIXED_CMD_SUFFIX;
const /** @type {?} */ TOGGLED_CMD_TOPIC_NAME = TOPIC_NAME_PREFIX + TOGGLED_CMD_SUFFIX;
// unsupported: template constraints.
/**
* <p style="text-indent: 2em;">
* An abstract base class for left side bar <code>nav menu</code>. This class provides more capabilities than [[AbstractNavMenu]] in case of that it can be
* showed/hidden by sliding the panel in/out from the left side of the screen. You can subscribe to the [[ObservableManager]]'s topic name
* <code>nav-left-layout.[sub-topic-name].toggled</code> to listen on the event emitted from this component when the left panel is <code>toggled</code>
* (showed/hidden). Futhermore, instead of sliding the panel in/out from the left side of the screen, it can be fixed by setting a flag [[fixed]] to <code>true</code>.
* By setting a flag [[fixed]] to <code>true</code>, the left panel will be always shown on the screen. This component will automatically publish an event to
* topic name <code>nav-left-layout.[sub-topic-name].fixed</code> when the flag [[fixed]] is changed. You can also control the <code>toggled</code> and <code>fixed</code>
* flag sending an event into <code>command</code> topic name <code>nav-left-layout.[sub-topic-name].cmd.toggled</code> and <code>nav-left-layout.[sub-topic-name].cmd.fixed</code>
* respectively.
* </p>
*
* @author shiorin, tee4cute
* @see [[ObservableManager]]
* @abstract
* @template T
*/
export class AbstractNavLeftLayout extends AbstractNavMenu {
/**
* @param {?} phloxAppService
* @param {?} observableMgr
* @param {?} subTopicName
*/
constructor(phloxAppService, observableMgr, subTopicName) {
super(AbstractNavLeftLayout.SUB_TOPIC_NAME, observableMgr);
if (phloxAppService !== null && typeof phloxAppService !== 'undefined') {
this.phloxAppService = phloxAppService;
}
this.observableMgr = observableMgr;
this.subTopicName = subTopicName;
this.fixed = false;
this.toggled = false;
this.fixedSubjects = [];
this.toggledSubjects = [];
}
/**
* @param {?} subTopicName
* @return {?}
*/
static getFixedChangeTopicName(subTopicName) {
if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') {
return AbstractNavLeftLayout.FIXED_CHANGE_TOPIC_NAME;
}
if (subTopicName.charAt(0) === '.') {
subTopicName = subTopicName.substring(1);
}
if (subTopicName === '') {
return AbstractNavLeftLayout.FIXED_CHANGE_TOPIC_NAME;
}
if (subTopicName.charAt(subTopicName.length - 1) !== '.') {
subTopicName += '.';
}
return TOPIC_NAME_PREFIX + subTopicName + FIXED_CHANGE_SUFFIX;
}
/**
* @param {?} subTopicName
* @return {?}
*/
static getToggledChangeTopicName(subTopicName) {
if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') {
return AbstractNavLeftLayout.TOGGLED_CHANGE_TOPIC_NAME;
}
if (subTopicName.charAt(0) === '.') {
subTopicName = subTopicName.substring(1);
}
if (subTopicName === '') {
return AbstractNavLeftLayout.TOGGLED_CHANGE_TOPIC_NAME;
}
if (subTopicName.charAt(subTopicName.length - 1) !== '.') {
subTopicName += '.';
}
return TOPIC_NAME_PREFIX + subTopicName + TOGGLED_CHANGE_SUFFIX;
}
/**
* @param {?} subTopicName
* @return {?}
*/
static getFixedCmdTopicName(subTopicName) {
if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') {
return AbstractNavLeftLayout.FIXED_CMD_TOPIC_NAME;
}
if (subTopicName.charAt(0) === '.') {
subTopicName = subTopicName.substring(1);
}
if (subTopicName === '') {
return AbstractNavLeftLayout.FIXED_CMD_TOPIC_NAME;
}
if (subTopicName.charAt(subTopicName.length - 1) !== '.') {
subTopicName += '.';
}
return TOPIC_NAME_PREFIX + subTopicName + FIXED_CMD_SUFFIX;
}
/**
* @param {?} subTopicName
* @return {?}
*/
static getToggledCmdTopicName(subTopicName) {
if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') {
return AbstractNavLeftLayout.TOGGLED_CMD_TOPIC_NAME;
}
if (subTopicName.charAt(0) === '.') {
subTopicName = subTopicName.substring(1);
}
if (subTopicName === '') {
return AbstractNavLeftLayout.TOGGLED_CMD_TOPIC_NAME;
}
if (subTopicName.charAt(subTopicName.length - 1) !== '.') {
subTopicName += '.';
}
return TOPIC_NAME_PREFIX + subTopicName + TOGGLED_CMD_SUFFIX;
}
/**
* @return {?}
*/
get app() {
if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') {
return null;
}
return this.phloxAppService.getInstance();
}
/**
* @return {?}
*/
get fixed() {
return this._fixed;
}
/**
* @param {?} newFixed
* @return {?}
*/
set fixed(newFixed) {
let /** @type {?} */ change = this._fixed !== newFixed;
this._fixed = newFixed;
if (change) {
this.onFixedChange(this._fixed);
// Emit change event
if (Array.isArray(this.fixedSubjects)) {
this.fixedSubjects.forEach((obsv, idx) => {
obsv.next(this);
});
}
}
}
/**
* @return {?}
*/
get toggled() {
return this._toggled;
}
/**
* @param {?} newToggled
* @return {?}
*/
set toggled(newToggled) {
let /** @type {?} */ change = this._toggled !== newToggled;
this._toggled = newToggled;
if (change) {
this.onToggledChange(this._toggled);
if (Array.isArray(this.toggledSubjects)) {
// Emit change event
this.toggledSubjects.forEach((obsv, idx) => {
obsv.next(this);
});
}
}
}
/**
* @param {?} fixedChange
* @param {?} toggledChanged
* @param {?} fixedCmd
* @param {?} toggledCmd
* @return {?}
*/
initNavLeftEventTopics(fixedChange, toggledChanged, fixedCmd, toggledCmd) {
// Create change event observable topics
if (fixedChange !== null && typeof fixedChange === 'string') {
this.fixedSubjects.push(this.observableMgr.createSubject(fixedChange));
}
if (toggledChanged !== null && typeof toggledChanged === 'string') {
this.toggledSubjects.push(this.observableMgr.createSubject(toggledChanged));
}
// Subscribe on CMD topics
if (fixedCmd !== null && typeof fixedCmd === 'string') {
this.observableMgr.subscribe(fixedCmd, (fixed) => {
if (typeof fixed === 'boolean') {
this.fixed = fixed;
}
});
}
if (toggledCmd !== null && typeof toggledCmd === 'string') {
this.observableMgr.subscribe(toggledCmd, (toggled) => {
if (typeof toggled === 'boolean') {
this.toggled = toggled;
}
});
}
}
/**
* @return {?}
*/
ngOnInit() {
super.ngOnInit();
// Init super class event topics
this.initNavLeftEventTopics(AbstractNavLeftLayout.FIXED_CHANGE_TOPIC_NAME, AbstractNavLeftLayout.TOGGLED_CHANGE_TOPIC_NAME, AbstractNavLeftLayout.FIXED_CMD_TOPIC_NAME, AbstractNavLeftLayout.TOGGLED_CMD_TOPIC_NAME);
if (this.subTopicName !== null && this.subTopicName !== '' || typeof this.subTopicName !== 'undefined') {
// Init sub topic event topics
this.initNavLeftEventTopics(AbstractNavLeftLayout.getFixedChangeTopicName(this.subTopicName), AbstractNavLeftLayout.getToggledChangeTopicName(this.subTopicName), AbstractNavLeftLayout.getFixedCmdTopicName(this.subTopicName), AbstractNavLeftLayout.getToggledCmdTopicName(this.subTopicName));
}
}
/**
* @return {?}
*/
getApplication() {
return this.app;
}
/**
* @return {?}
*/
getSubTopicName() {
return this.subTopicName;
}
/**
* @return {?}
*/
isFixed() {
return this.fixed;
}
/**
* @param {?} fixed
* @return {?}
*/
setFixed(fixed) {
this.fixed = fixed;
}
/**
* @return {?}
*/
isToggled() {
return this.toggled;
}
/**
* @param {?} toggled
* @return {?}
*/
setToggled(toggled) {
this.toggled = toggled;
}
}
AbstractNavLeftLayout.FIXED_CHANGE_TOPIC_NAME = FIXED_CHANGE_TOPIC_NAME;
AbstractNavLeftLayout.TOGGLED_CHANGE_TOPIC_NAME = TOGGLED_CHANGE_TOPIC_NAME;
AbstractNavLeftLayout.FIXED_CMD_TOPIC_NAME = FIXED_CMD_TOPIC_NAME;
AbstractNavLeftLayout.TOGGLED_CMD_TOPIC_NAME = TOGGLED_CMD_TOPIC_NAME;
AbstractNavLeftLayout.SUB_TOPIC_NAME = SUB_TOPIC_NAME;
function AbstractNavLeftLayout_tsickle_Closure_declarations() {
/** @type {?} */
AbstractNavLeftLayout.FIXED_CHANGE_TOPIC_NAME;
/** @type {?} */
AbstractNavLeftLayout.TOGGLED_CHANGE_TOPIC_NAME;
/** @type {?} */
AbstractNavLeftLayout.FIXED_CMD_TOPIC_NAME;
/** @type {?} */
AbstractNavLeftLayout.TOGGLED_CMD_TOPIC_NAME;
/** @type {?} */
AbstractNavLeftLayout.SUB_TOPIC_NAME;
/** @type {?} */
AbstractNavLeftLayout.prototype._fixed;
/** @type {?} */
AbstractNavLeftLayout.prototype._toggled;
/** @type {?} */
AbstractNavLeftLayout.prototype.phloxAppService;
/** @type {?} */
AbstractNavLeftLayout.prototype.fixedSubjects;
/** @type {?} */
AbstractNavLeftLayout.prototype.toggledSubjects;
/** @type {?} */
AbstractNavLeftLayout.prototype.subTopicName;
/**
* @abstract
* @param {?} fixed
* @return {?}
*/
AbstractNavLeftLayout.prototype.onFixedChange = function (fixed) { };
/**
* @abstract
* @param {?} toggled
* @return {?}
*/
AbstractNavLeftLayout.prototype.onToggledChange = function (toggled) { };
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractNavLeftLayout.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/AbstractNavLeftLayout.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 } from '../service/ObservableManager.service';\nimport { PhloxAppService } from '../service/PhloxAppService.service';\nimport { AbstractNavItem } from './AbstractNavItem';\nimport { AbstractNavMenu } from './AbstractNavMenu';\n\nconst SUB_TOPIC_NAME: string = 'nav-left-layout';\nconst TOPIC_NAME_PREFIX: string = 'nav-left-layout.';\n\nconst FIXED_CHANGE_SUFFIX: string = 'fixed';\nconst TOGGLED_CHANGE_SUFFIX: string = 'toggled';\nconst FIXED_CMD_SUFFIX: string = 'cmd.fixed';\nconst TOGGLED_CMD_SUFFIX: string = 'cmd.toggled';\n\nconst FIXED_CHANGE_TOPIC_NAME: string = TOPIC_NAME_PREFIX + FIXED_CHANGE_SUFFIX;\nconst TOGGLED_CHANGE_TOPIC_NAME: string = TOPIC_NAME_PREFIX + TOGGLED_CHANGE_SUFFIX;\n\nconst FIXED_CMD_TOPIC_NAME: string = TOPIC_NAME_PREFIX + FIXED_CMD_SUFFIX;\nconst TOGGLED_CMD_TOPIC_NAME: string = TOPIC_NAME_PREFIX + TOGGLED_CMD_SUFFIX;\n\n/**\n * <p style=\"text-indent: 2em;\">\n * An abstract base class for left side bar <code>nav menu</code>. This class provides more capabilities than [[AbstractNavMenu]] in case of that it can be\n * showed/hidden by sliding the panel in/out from the left side of the screen. You can subscribe to the [[ObservableManager]]'s topic name\n * <code>nav-left-layout.[sub-topic-name].toggled</code> to listen on the event emitted from this component when the left panel is <code>toggled</code>\n * (showed/hidden). Futhermore, instead of sliding the panel in/out from the left side of the screen, it can be fixed by setting a flag [[fixed]] to <code>true</code>.\n * By setting a flag [[fixed]] to <code>true</code>, the left panel will be always shown on the screen. This component will automatically publish an event to\n * topic name <code>nav-left-layout.[sub-topic-name].fixed</code> when the flag [[fixed]] is changed. You can also control the <code>toggled</code> and <code>fixed</code>\n * flag sending an event into <code>command</code> topic name <code>nav-left-layout.[sub-topic-name].cmd.toggled</code> and <code>nav-left-layout.[sub-topic-name].cmd.fixed</code>\n * respectively.\n * </p>\n *\n * @author shiorin, tee4cute\n * @see [[ObservableManager]]\n */\nexport abstract class AbstractNavLeftLayout<T extends AbstractNavItem> extends AbstractNavMenu<T> implements IApplicationAware, OnInit {\n\n    public static readonly FIXED_CHANGE_TOPIC_NAME: string = FIXED_CHANGE_TOPIC_NAME;\n    public static readonly TOGGLED_CHANGE_TOPIC_NAME: string = TOGGLED_CHANGE_TOPIC_NAME;\n    public static readonly FIXED_CMD_TOPIC_NAME: string = FIXED_CMD_TOPIC_NAME;\n    public static readonly TOGGLED_CMD_TOPIC_NAME: string = TOGGLED_CMD_TOPIC_NAME;\n    public static readonly SUB_TOPIC_NAME: string = SUB_TOPIC_NAME;\n\n    public static getFixedChangeTopicName(subTopicName: string): string {\n        if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') {\n            return AbstractNavLeftLayout.FIXED_CHANGE_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(0) === '.') {\n            subTopicName = subTopicName.substring(1);\n        }\n\n        if (subTopicName === '') {\n            return AbstractNavLeftLayout.FIXED_CHANGE_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(subTopicName.length - 1) !== '.') {\n            subTopicName += '.';\n        }\n\n        return TOPIC_NAME_PREFIX + subTopicName + FIXED_CHANGE_SUFFIX;\n    }\n\n    public static getToggledChangeTopicName(subTopicName: string): string {\n        if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') {\n            return AbstractNavLeftLayout.TOGGLED_CHANGE_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(0) === '.') {\n            subTopicName = subTopicName.substring(1);\n        }\n\n        if (subTopicName === '') {\n            return AbstractNavLeftLayout.TOGGLED_CHANGE_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(subTopicName.length - 1) !== '.') {\n            subTopicName += '.';\n        }\n\n        return TOPIC_NAME_PREFIX + subTopicName + TOGGLED_CHANGE_SUFFIX;\n    }\n\n    public static getFixedCmdTopicName(subTopicName: string): string {\n        if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') {\n            return AbstractNavLeftLayout.FIXED_CMD_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(0) === '.') {\n            subTopicName = subTopicName.substring(1);\n        }\n\n        if (subTopicName === '') {\n            return AbstractNavLeftLayout.FIXED_CMD_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(subTopicName.length - 1) !== '.') {\n            subTopicName += '.';\n        }\n\n        return TOPIC_NAME_PREFIX + subTopicName + FIXED_CMD_SUFFIX;\n    }\n\n    public static getToggledCmdTopicName(subTopicName: string): string {\n        if (subTopicName === null || typeof subTopicName === 'undefined' || subTopicName === '') {\n            return AbstractNavLeftLayout.TOGGLED_CMD_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(0) === '.') {\n            subTopicName = subTopicName.substring(1);\n        }\n\n        if (subTopicName === '') {\n            return AbstractNavLeftLayout.TOGGLED_CMD_TOPIC_NAME;\n        }\n\n        if (subTopicName.charAt(subTopicName.length - 1) !== '.') {\n            subTopicName += '.';\n        }\n\n        return TOPIC_NAME_PREFIX + subTopicName + TOGGLED_CMD_SUFFIX;\n    }\n\n    private _fixed: boolean;\n    private _toggled: boolean;\n\n    protected phloxAppService: PhloxAppService;\n    protected fixedSubjects: Subject<any>[];\n    protected toggledSubjects: Subject<any>[];\n    protected subTopicName: string;\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, subTopicName: string) {\n        super(AbstractNavLeftLayout.SUB_TOPIC_NAME, observableMgr);\n\n        if (phloxAppService !== null && typeof phloxAppService !== 'undefined') {\n            this.phloxAppService = phloxAppService;\n        }\n        this.observableMgr = observableMgr;\n        this.subTopicName = subTopicName;\n        this.fixed = false;\n        this.toggled = false;\n\n        this.fixedSubjects = [];\n        this.toggledSubjects = [];\n    }\n\n    public get fixed(): boolean {\n        return this._fixed;\n    }\n\n    public set fixed(newFixed: boolean) {\n        let change: boolean = this._fixed !== newFixed;\n\n        this._fixed = newFixed;\n\n        if (change) {\n            this.onFixedChange(this._fixed);\n\n            // Emit change event\n            if (Array.isArray(this.fixedSubjects)) {\n                this.fixedSubjects.forEach((obsv, idx) => {\n                    obsv.next(this);\n                });\n            }\n        }\n    }\n\n    public get toggled(): boolean {\n        return this._toggled;\n    }\n\n    public set toggled(newToggled: boolean) {\n        let change: boolean = this._toggled !== newToggled;\n\n        this._toggled = newToggled;\n\n        if (change) {\n            this.onToggledChange(this._toggled);\n\n            if (Array.isArray(this.toggledSubjects)) {\n                // Emit change event\n                this.toggledSubjects.forEach((obsv, idx) => {\n                    obsv.next(this);\n                });\n            }\n        }\n    }\n\n    private initNavLeftEventTopics(fixedChange: string, toggledChanged: string, fixedCmd: string, toggledCmd: string): void {\n        // Create change event observable topics\n        if (fixedChange !== null && typeof fixedChange === 'string') {\n          this.fixedSubjects.push(this.observableMgr.createSubject(fixedChange));\n        }\n        if (toggledChanged !== null && typeof toggledChanged === 'string') {\n          this.toggledSubjects.push(this.observableMgr.createSubject(toggledChanged));\n        }\n\n        // Subscribe on CMD topics\n        if (fixedCmd !== null && typeof fixedCmd === 'string') {\n          this.observableMgr.subscribe(fixedCmd, (fixed: any) => {\n              if (typeof fixed === 'boolean') {\n                  this.fixed = fixed;\n              }\n          });\n        }\n        if (toggledCmd !== null && typeof toggledCmd === 'string') {\n          this.observableMgr.subscribe(toggledCmd, (toggled: any) => {\n              if (typeof toggled === 'boolean') {\n                  this.toggled = toggled;\n              }\n          });\n        }\n    }\n\n    public ngOnInit(): void {\n        super.ngOnInit();\n\n        // Init super class event topics\n        this.initNavLeftEventTopics(\n            AbstractNavLeftLayout.FIXED_CHANGE_TOPIC_NAME,\n            AbstractNavLeftLayout.TOGGLED_CHANGE_TOPIC_NAME,\n            AbstractNavLeftLayout.FIXED_CMD_TOPIC_NAME,\n            AbstractNavLeftLayout.TOGGLED_CMD_TOPIC_NAME\n        );\n\n        if (this.subTopicName !== null && this.subTopicName !== '' || typeof this.subTopicName !== 'undefined') {\n            // Init sub topic event topics\n            this.initNavLeftEventTopics(\n                AbstractNavLeftLayout.getFixedChangeTopicName(this.subTopicName),\n                AbstractNavLeftLayout.getToggledChangeTopicName(this.subTopicName),\n                AbstractNavLeftLayout.getFixedCmdTopicName(this.subTopicName),\n                AbstractNavLeftLayout.getToggledCmdTopicName(this.subTopicName)\n            );\n        }\n    }\n\n    public getApplication(): PhloxApp {\n        return this.app;\n    }\n\n    public getSubTopicName(): string {\n        return this.subTopicName;\n    }\n\n    public isFixed(): boolean {\n        return this.fixed;\n    }\n\n    public setFixed(fixed: boolean): void {\n        this.fixed = fixed;\n    }\n\n    public isToggled(): boolean {\n        return this.toggled;\n    }\n\n    public setToggled(toggled: boolean): void {\n        this.toggled = toggled;\n    }\n\n    public abstract onFixedChange(fixed: boolean): void;\n\n    public abstract onToggledChange(toggled: boolean): void;\n\n}\n"]}