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