UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

151 lines (150 loc) 12.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ 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'; const /** @type {?} */ TYPE_NAME = "phx-layout-menu-top"; const /** @type {?} */ SUB_TOPIC_NAME = 'menu-top-layout'; export class MenuTopLayout extends AbstractNavMenu { /** * @param {?} phloxAppService * @param {?} menuItemProvider * @param {?} obsvMgr */ constructor(phloxAppService, menuItemProvider, obsvMgr) { super(MenuTopLayout.SUB_TOPIC_NAME, obsvMgr); if (phloxAppService !== null && typeof phloxAppService !== 'undefined') { this.phloxAppService = phloxAppService; } this.menuItemProvider = menuItemProvider; this.itemModels = []; } /** * @return {?} */ get app() { if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') { return null; } return this.phloxAppService.getInstance(); } /** * @return {?} */ ngOnInit() { super.ngOnInit(); // Auto load menu this.reloadMenuItems().then((result) => { if (result) { } else { console.warn('Could not load main menu items.'); } }); } /** * @return {?} */ getApplication() { return this.app; } /** * @return {?} */ getMenuItems() { return this.itemModels; } /** * @return {?} */ reloadMenuItems() { return this.menuItemProvider.reload().then((items) => { if (items === null) { items = []; } this.itemModels = items; return Promise.resolve(true); }); } /** * @param {?} item * @return {?} */ doNavigate(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-layout-menu-top"> <div class="container-fluid"> <div class="phlox-app-pane-wrapper"> <div class="phlox-app-pane"> <div class="logo"></div> <h3 class="label"> {{ getApplication().getAppInfo().name }} <small>{{ getApplication().getAppInfo().tagline }}</small> </h3> </div> </div> <div class="phx-app-switcher-wrapper"> <phx-app-switcher></phx-app-switcher> </div> <div class="phlox-main-nav-wrapper"> <div class="phlox-main-nav"> <div class="phx-menu-top-item" *ngFor="let item of getMenuItems()" [layout]="this" [model]="item"></div> </div> </div> <div class="phx-addon-drawer-wrapper"> <div class="bg-border"> <!-- fake bg with border--> </div> <phx-addon-drawer></phx-addon-drawer> </div> <div class="phlox-notifier-wrapper"> <phx-notifier></phx-notifier> </div> </div> </div> ` },] }, ]; /** @nocollapse */ MenuTopLayout.ctorParameters = () => [ { type: PhloxAppService, }, { type: MainMenuItemProvider, }, { type: ObservableManager, }, ]; 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.phloxAppService; /** @type {?} */ MenuTopLayout.prototype.menuItemProvider; /** @type {?} */ MenuTopLayout.prototype.itemModels; } export { PhloxAddonDrawer } from './menu.internal/PhloxAddonDrawer.component'; export { PhloxNotifier } from './menu.internal/PhloxNotifier.component'; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"MenuTopLayout.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/page/main/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 './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';\n\nconst TYPE_NAME: string = \"phx-layout-menu-top\";\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-layout-menu-top\">\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  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 './menu.internal/PhloxAddonDrawer.component';\nexport * from './menu.internal/PhloxNotifier.component';\n"]}