com.phloxui
Version:
PhloxUI Ng2+ Framework
155 lines (154 loc) • 14.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component } from '@angular/core';
import { AbstractNavMenu } from './AbstractNavMenu';
import { MainMenuItemProvider } from '../service/MainMenuItemProvider.service';
import { ObservableManager } from '../service/ObservableManager.service';
import { PhloxAppService } from '../service/PhloxAppService.service';
import { Option } from '../decorator/decorators';
var /** @type {?} */ TYPE_NAME = "phx-menu-top-layout";
var /** @type {?} */ SUB_TOPIC_NAME = 'menu-top-layout';
var MenuTopLayout = /** @class */ (function (_super) {
tslib_1.__extends(MenuTopLayout, _super);
function MenuTopLayout(phloxAppService, menuItemProvider, obsvMgr) {
var _this = _super.call(this, MenuTopLayout.SUB_TOPIC_NAME, obsvMgr) || this;
if (phloxAppService !== null && typeof phloxAppService !== 'undefined') {
_this.phloxAppService = phloxAppService;
}
_this.menuItemProvider = menuItemProvider;
_this.itemModels = [];
return _this;
}
Object.defineProperty(MenuTopLayout.prototype, "app", {
get: /**
* @return {?}
*/
function () {
if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') {
return null;
}
return this.phloxAppService.getInstance();
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
MenuTopLayout.prototype.ngOnInit = /**
* @return {?}
*/
function () {
_super.prototype.ngOnInit.call(this);
// Auto load menu
this.reloadMenuItems().then(function (result) {
if (result) {
}
else {
console.warn('Could not load main menu items.');
}
});
};
/**
* @return {?}
*/
MenuTopLayout.prototype.getApplication = /**
* @return {?}
*/
function () {
return this.app;
};
/**
* @return {?}
*/
MenuTopLayout.prototype.getMenuItems = /**
* @return {?}
*/
function () {
return this.itemModels;
};
/**
* @return {?}
*/
MenuTopLayout.prototype.reloadMenuItems = /**
* @return {?}
*/
function () {
var _this = this;
return this.menuItemProvider.reload().then(function (items) {
if (items === null) {
items = [];
}
_this.itemModels = items;
return Promise.resolve(true);
});
};
/**
* @param {?} item
* @return {?}
*/
MenuTopLayout.prototype.doNavigate = /**
* @param {?} item
* @return {?}
*/
function (item) {
if (item.getModel().getLink() === null || typeof item.getModel().getLink() !== 'string') {
return Promise.resolve(false);
}
return this.app.getRouter().navigate([item.getModel().getLink()]);
};
MenuTopLayout.TYPE_NAME = TYPE_NAME;
MenuTopLayout.SUB_TOPIC_NAME = SUB_TOPIC_NAME;
MenuTopLayout.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"phx-menu-top-layout\">\n\t<div class=\"container-fluid\">\n\t\t<div class=\"phlox-app-pane-wrapper\">\n\t\t\t<div class=\"phlox-app-pane\">\n\t\t\t\t<div class=\"logo\"></div>\n\t\t\t\t<h3 class=\"label\">\n\t\t\t\t\t{{ getApplication().getAppInfo().name }}\n\t\t\t\t\t<small>{{ getApplication().getAppInfo().tagline }}</small>\n\t\t\t\t</h3>\n\t\t\t</div>\n\t\t</div>\n\t\t<div class=\"phx-app-switcher-wrapper\">\n\t\t\t <phx-app-switcher></phx-app-switcher>\n\t\t</div>\n\t\t<div class=\"phlox-main-nav-wrapper\">\n\t\t\t<div class=\"phlox-main-nav\">\n\t\t\t\t<div class=\"phx-menu-top-item\" *ngFor=\"let item of getMenuItems()\" [layout]=\"this\" [model]=\"item\"></div>\n\t\t\t</div>\n\t\t</div>\n\t\t<div class=\"phx-addon-drawer-wrapper\">\n\t\t\t<div class=\"bg-border\">\n\t\t\t\t<!-- fake bg with border-->\n\t\t\t</div>\n\t\t\t<phx-addon-drawer></phx-addon-drawer>\n\t\t</div>\n\t\t<div class=\"phlox-notifier-wrapper\">\n\t\t\t<phx-notifier></phx-notifier>\n\t\t</div>\n\t</div>\n</div>\n"
},] },
];
/** @nocollapse */
MenuTopLayout.ctorParameters = function () { return [
{ type: PhloxAppService, },
{ type: MainMenuItemProvider, },
{ type: ObservableManager, },
]; };
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], MenuTopLayout.prototype, "i18nKey", void 0);
tslib_1.__decorate([
Option('i18nBypass'),
tslib_1.__metadata("design:type", Boolean)
], MenuTopLayout.prototype, "bypass", void 0);
return MenuTopLayout;
}(AbstractNavMenu));
export { MenuTopLayout };
function MenuTopLayout_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
MenuTopLayout.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
MenuTopLayout.ctorParameters;
/** @type {?} */
MenuTopLayout.TYPE_NAME;
/** @type {?} */
MenuTopLayout.SUB_TOPIC_NAME;
/** @type {?} */
MenuTopLayout.prototype.i18nKey;
/** @type {?} */
MenuTopLayout.prototype.bypass;
/** @type {?} */
MenuTopLayout.prototype.phloxAppService;
/** @type {?} */
MenuTopLayout.prototype.menuItemProvider;
/** @type {?} */
MenuTopLayout.prototype.itemModels;
}
export { PhloxAddonDrawer } from './page/main/menu.internal/PhloxAddonDrawer.component';
export { PhloxNotifier } from './page/main/menu.internal/PhloxNotifier.component';
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MenuTopLayout.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/MenuTopLayout.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, Type } from '@angular/core';\n\nimport { IApplicationAware } from './IApplicationAware';\nimport { PhloxApp } from './PhloxApp.component';\nimport { AbstractNavMenu } from './AbstractNavMenu';\nimport { MenuTopItem } from './menuTopLayout.internal/MenuTopItem.component';\nimport { PhloxMainMenuItem } from './model/models';\nimport { MainMenuItemProvider } from '../service/MainMenuItemProvider.service';\nimport { ObservableManager } from '../service/ObservableManager.service';\nimport { PhloxAppService } from '../service/PhloxAppService.service';\nimport { Option } from '../decorator/decorators';\n\nconst TYPE_NAME: string = \"phx-menu-top-layout\";\n\nconst SUB_TOPIC_NAME: string = 'menu-top-layout';\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-menu-top-layout\">\n\t<div class=\"container-fluid\">\n\t\t<div class=\"phlox-app-pane-wrapper\">\n\t\t\t<div class=\"phlox-app-pane\">\n\t\t\t\t<div class=\"logo\"></div>\n\t\t\t\t<h3 class=\"label\">\n\t\t\t\t\t{{ getApplication().getAppInfo().name }}\n\t\t\t\t\t<small>{{ getApplication().getAppInfo().tagline }}</small>\n\t\t\t\t</h3>\n\t\t\t</div>\n\t\t</div>\n\t\t<div class=\"phx-app-switcher-wrapper\">\n\t\t\t <phx-app-switcher></phx-app-switcher>\n\t\t</div>\n\t\t<div class=\"phlox-main-nav-wrapper\">\n\t\t\t<div class=\"phlox-main-nav\">\n\t\t\t\t<div class=\"phx-menu-top-item\" *ngFor=\"let item of getMenuItems()\" [layout]=\"this\" [model]=\"item\"></div>\n\t\t\t</div>\n\t\t</div>\n\t\t<div class=\"phx-addon-drawer-wrapper\">\n\t\t\t<div class=\"bg-border\">\n\t\t\t\t<!-- fake bg with border-->\n\t\t\t</div>\n\t\t\t<phx-addon-drawer></phx-addon-drawer>\n\t\t</div>\n\t\t<div class=\"phlox-notifier-wrapper\">\n\t\t\t<phx-notifier></phx-notifier>\n\t\t</div>\n\t</div>\n</div>\n`\n})\nexport class MenuTopLayout extends AbstractNavMenu<MenuTopItem> implements IApplicationAware, OnInit {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  public static readonly SUB_TOPIC_NAME: string = SUB_TOPIC_NAME;\n\n  @Option()\n  protected i18nKey: string;\n  @Option('i18nBypass')\n  protected bypass: boolean;\n\n  private phloxAppService: PhloxAppService;\n  private menuItemProvider: MainMenuItemProvider;\n  private itemModels: PhloxMainMenuItem[];\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, menuItemProvider: MainMenuItemProvider, obsvMgr: ObservableManager) {\n    super(MenuTopLayout.SUB_TOPIC_NAME, obsvMgr);\n\n    if (phloxAppService !== null && typeof phloxAppService !== 'undefined') {\n      this.phloxAppService = phloxAppService;\n    }\n    this.menuItemProvider = menuItemProvider;\n    this.itemModels = [];\n  }\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n\n    // Auto load menu\n    this.reloadMenuItems().then((result) => {\n      if (result) {\n      } else {\n        console.warn('Could not load main menu items.');\n      }\n    });\n  }\n\n  public getApplication(): PhloxApp {\n    return this.app;\n  }\n\n  public getMenuItems(): PhloxMainMenuItem[] {\n    return this.itemModels;\n  }\n\n  public reloadMenuItems(): Promise<boolean> {\n    return this.menuItemProvider.reload().then((items: PhloxMainMenuItem[]) => {\n      if (items === null) {\n        items = [];\n      }\n\n      this.itemModels = items;\n\n      return Promise.resolve(true);\n    });\n  }\n\n  public doNavigate(item: MenuTopItem): Promise<boolean> {\n    if (item.getModel().getLink() === null || typeof item.getModel().getLink() !== 'string') {\n      return Promise.resolve(false);\n    }\n\n    return this.app.getRouter().navigate([item.getModel().getLink()]);\n  }\n}\n\nexport * from './page/main/menu.internal/PhloxAddonDrawer.component';\nexport * from './page/main/menu.internal/PhloxNotifier.component';\n"]}