UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

368 lines (367 loc) 35.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { AbstractNavMenu } from './AbstractNavMenu'; var /** @type {?} */ SUB_TOPIC_NAME = 'nav-left-layout'; var /** @type {?} */ TOPIC_NAME_PREFIX = 'nav-left-layout.'; var /** @type {?} */ FIXED_CHANGE_SUFFIX = 'fixed'; var /** @type {?} */ TOGGLED_CHANGE_SUFFIX = 'toggled'; var /** @type {?} */ FIXED_CMD_SUFFIX = 'cmd.fixed'; var /** @type {?} */ TOGGLED_CMD_SUFFIX = 'cmd.toggled'; var /** @type {?} */ FIXED_CHANGE_TOPIC_NAME = TOPIC_NAME_PREFIX + FIXED_CHANGE_SUFFIX; var /** @type {?} */ TOGGLED_CHANGE_TOPIC_NAME = TOPIC_NAME_PREFIX + TOGGLED_CHANGE_SUFFIX; var /** @type {?} */ FIXED_CMD_TOPIC_NAME = TOPIC_NAME_PREFIX + FIXED_CMD_SUFFIX; var /** @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 */ var AbstractNavLeftLayout = /** @class */ (function (_super) { tslib_1.__extends(AbstractNavLeftLayout, _super); function AbstractNavLeftLayout(phloxAppService, observableMgr, subTopicName) { var _this = _super.call(this, AbstractNavLeftLayout.SUB_TOPIC_NAME, observableMgr) || this; 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 = []; return _this; } /** * @param {?} subTopicName * @return {?} */ AbstractNavLeftLayout.getFixedChangeTopicName = /** * @param {?} subTopicName * @return {?} */ function (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 {?} */ AbstractNavLeftLayout.getToggledChangeTopicName = /** * @param {?} subTopicName * @return {?} */ function (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 {?} */ AbstractNavLeftLayout.getFixedCmdTopicName = /** * @param {?} subTopicName * @return {?} */ function (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 {?} */ AbstractNavLeftLayout.getToggledCmdTopicName = /** * @param {?} subTopicName * @return {?} */ function (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; }; Object.defineProperty(AbstractNavLeftLayout.prototype, "app", { get: /** * @return {?} */ function () { if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') { return null; } return this.phloxAppService.getInstance(); }, enumerable: true, configurable: true }); Object.defineProperty(AbstractNavLeftLayout.prototype, "fixed", { get: /** * @return {?} */ function () { return this._fixed; }, set: /** * @param {?} newFixed * @return {?} */ function (newFixed) { var _this = this; var /** @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(function (obsv, idx) { obsv.next(_this); }); } } }, enumerable: true, configurable: true }); Object.defineProperty(AbstractNavLeftLayout.prototype, "toggled", { get: /** * @return {?} */ function () { return this._toggled; }, set: /** * @param {?} newToggled * @return {?} */ function (newToggled) { var _this = this; var /** @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(function (obsv, idx) { obsv.next(_this); }); } } }, enumerable: true, configurable: true }); /** * @param {?} fixedChange * @param {?} toggledChanged * @param {?} fixedCmd * @param {?} toggledCmd * @return {?} */ AbstractNavLeftLayout.prototype.initNavLeftEventTopics = /** * @param {?} fixedChange * @param {?} toggledChanged * @param {?} fixedCmd * @param {?} toggledCmd * @return {?} */ function (fixedChange, toggledChanged, fixedCmd, toggledCmd) { var _this = this; // 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, function (fixed) { if (typeof fixed === 'boolean') { _this.fixed = fixed; } }); } if (toggledCmd !== null && typeof toggledCmd === 'string') { this.observableMgr.subscribe(toggledCmd, function (toggled) { if (typeof toggled === 'boolean') { _this.toggled = toggled; } }); } }; /** * @return {?} */ AbstractNavLeftLayout.prototype.ngOnInit = /** * @return {?} */ function () { _super.prototype.ngOnInit.call(this); // 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 {?} */ AbstractNavLeftLayout.prototype.getApplication = /** * @return {?} */ function () { return this.app; }; /** * @return {?} */ AbstractNavLeftLayout.prototype.getSubTopicName = /** * @return {?} */ function () { return this.subTopicName; }; /** * @return {?} */ AbstractNavLeftLayout.prototype.isFixed = /** * @return {?} */ function () { return this.fixed; }; /** * @param {?} fixed * @return {?} */ AbstractNavLeftLayout.prototype.setFixed = /** * @param {?} fixed * @return {?} */ function (fixed) { this.fixed = fixed; }; /** * @return {?} */ AbstractNavLeftLayout.prototype.isToggled = /** * @return {?} */ function () { return this.toggled; }; /** * @param {?} toggled * @return {?} */ AbstractNavLeftLayout.prototype.setToggled = /** * @param {?} toggled * @return {?} */ function (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; return AbstractNavLeftLayout; }(AbstractNavMenu)); export { AbstractNavLeftLayout }; 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"]}