UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

307 lines (306 loc) 33.7 kB
/** * @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"]}