UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

316 lines (315 loc) 27.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import { Component, Input, ElementRef } from '@angular/core'; import { ActionModelMenu } from '../model/ActionModelMenu'; const /** @type {?} */ TYPE_NAME = "phx-action-menu-bar"; export class ActionMenuBar { /** * @param {?} elementRef */ constructor(elementRef) { this.elementRef = elementRef; this.isShowMoreMenu = false; this.moreActionModels = []; this.activeActionModels = []; this.isRendering = false; let /** @type {?} */ showFunction = () => { return true; }; let /** @type {?} */ enableFunction = () => { return true; }; // let actionPerformedHandler: Function = () => { // console.log("MORE"); // }; this.moreModel = new ActionModelMenu(null, "More", "other", showFunction, enableFunction, null, this.moreActionModels); } /** * @return {?} */ ngOnInit() { this.init(); this.reload(); } /** * @return {?} */ ngOnDestroy() { if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') { this.contextMenu.setContext(null); } } /** * @return {?} */ init() { if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') { this.contextMenu.setContext(this); } if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') { this.menuModel = this.menuFactory.createMenuModel(this); } /* this.activeActionModels = []; if (this.models != null && typeof this.models !== 'undefined') { for(let item of this.models){ this.activeActionModels.push(item); } } */ } /** * @return {?} */ reRenderActionMenuBar() { if (this.maxWidth !== null && typeof this.maxWidth !== 'undefined') { let /** @type {?} */ tempMap = {}; let /** @type {?} */ allWidth = 0; $(this.elementRef.nativeElement).find(".phx-action-menu-bar >.action").each((index, value) => { let /** @type {?} */ width = $(value).width(); allWidth += width; let /** @type {?} */ indexString = index + ""; tempMap[indexString] = { width: width }; }); // remove from actions this.moreActionModels = []; if (allWidth > this.maxWidth) { let /** @type {?} */ tempArray = []; let /** @type {?} */ currentWidth = 0; for (let /** @type {?} */ i = 0; i < this.activeActionModels.length; i++) { let /** @type {?} */ indexString = i + ""; let /** @type {?} */ model = this.activeActionModels[i]; let /** @type {?} */ width = 0; if (tempMap[indexString] !== null && typeof tempMap[indexString] !== 'undefined') { width = tempMap[indexString].width; currentWidth += width; } if (currentWidth > this.maxWidth) { tempArray.push(model); } } for (let /** @type {?} */ item of tempArray) { let /** @type {?} */ removeIdx = this.activeActionModels.indexOf(item); if (removeIdx > -1) { this.activeActionModels.splice(removeIdx, 1); } this.moreActionModels.push(item); } } if (this.moreModel instanceof ActionModelMenu) { this.moreModel.items = this.moreActionModels; } } else { // clear moreItem this.moreActionModels = []; if (this.moreModel instanceof ActionModelMenu) { this.moreModel.items = this.moreActionModels; } } } /** * @return {?} */ getTopMoreMenu() { let /** @type {?} */ height = $(this.elementRef.nativeElement).find(".action-menu-bar").height(); return height - 10; } /** * @return {?} */ getLeftMoreMenu() { let /** @type {?} */ position = $(this.elementRef.nativeElement).find(".action-menu-bar >.more").position(); let /** @type {?} */ left = 0; if (typeof position !== 'undefined') { left = position.left; } return left; } /** * @param {?} show * @return {?} */ showMoreMenu(show) { this.isShowMoreMenu = show; } /** * @return {?} */ _isRendering() { return this.isRendering; } /** * @param {?} $event * @return {?} */ onMoreBtnClicked($event) { if (this.isShowMoreMenu) { this.showMoreMenu(false); } else { this.showMoreMenu(true); } } /** * @param {?} model * @return {?} */ isShow(model) { if (model.isShow === null) { return false; } if (typeof model.isShow !== 'function') { return false; } return model.isShow(this); } /** * @param {?} model * @return {?} */ isEnabled(model) { if (model.isEnabled === null) { return false; } if (typeof model.isEnabled !== 'function') { return false; } return model.isEnabled(this); } /** * @return {?} */ isShowMore() { return this.moreActionModels.length > 0 ? true : false; } /** * @return {?} */ reload() { this.activeActionModels = []; if (this.models != null && typeof this.models !== 'undefined') { for (let /** @type {?} */ item of this.models) { this.activeActionModels.push(item); } } if (this.delayTimer !== null && typeof this.delayTimer !== 'undefined') { clearTimeout(this.delayTimer); this.delayTimer = null; } this.isRendering = true; this.delayTimer = setTimeout(() => { this.reRenderActionMenuBar(); this.isRendering = false; }, 1); } /** * @return {?} */ getContextMenu() { return this.contextMenu; } /** * @param {?} menu * @return {?} */ setContextMenu(menu) { this.contextMenu = menu; } /** * @return {?} */ getMenuModelFactory() { return this.menuFactory; } /** * @param {?} menuFactory * @return {?} */ setMenuModelFactory(menuFactory) { this.menuFactory = menuFactory; } /** * @param {?} maxWidth * @return {?} */ setMaxWidth(maxWidth) { this.maxWidth = maxWidth; this.reload(); } /** * @return {?} */ getMoreModel() { return this.moreModel; } /** * @return {?} */ getActiveActionModels() { return this.activeActionModels; } } ActionMenuBar.TYPE_NAME = TYPE_NAME; ActionMenuBar.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: `<div class="phx-action-menu-bar" [class.rendering]="_isRendering()"> <div *ngFor="let action of getActiveActionModels()" class="action"> <phx-action-btn [model]="action" *ngIf="isShow(action)"></phx-action-btn> </div> <div class="more"> <phx-action-btn [model]="getMoreModel()" *ngIf="isShowMore()" (click)="onMoreBtnClicked($event)"></phx-action-btn> </div> </div> ` },] }, ]; /** @nocollapse */ ActionMenuBar.ctorParameters = () => [ { type: ElementRef, }, ]; ActionMenuBar.propDecorators = { "menuFactory": [{ type: Input },], "models": [{ type: Input },], "maxWidth": [{ type: Input },], }; function ActionMenuBar_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ ActionMenuBar.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ ActionMenuBar.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ ActionMenuBar.propDecorators; /** @type {?} */ ActionMenuBar.TYPE_NAME; /** @type {?} */ ActionMenuBar.prototype.menuFactory; /** @type {?} */ ActionMenuBar.prototype.models; /** @type {?} */ ActionMenuBar.prototype.maxWidth; /** @type {?} */ ActionMenuBar.prototype.activeActionModels; /** @type {?} */ ActionMenuBar.prototype.moreActionModels; /** @type {?} */ ActionMenuBar.prototype.contextMenu; /** @type {?} */ ActionMenuBar.prototype.menuModel; /** @type {?} */ ActionMenuBar.prototype.moreModel; /** @type {?} */ ActionMenuBar.prototype.elementRef; /** @type {?} */ ActionMenuBar.prototype.delayTimer; /** @type {?} */ ActionMenuBar.prototype.isRendering; /** @type {?} */ ActionMenuBar.prototype.isShowMoreMenu; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ActionMenuBar.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/editor/ActionMenuBar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, ElementRef, OnDestroy } from '@angular/core';\nimport { ActionModel } from '../model/ActionModel';\nimport { ActionModelMenu } from '../model/ActionModelMenu';\nimport { MenuModel } from '../model/MenuModel';\nimport { ContextMenu } from '../ContextMenu.component';\nimport { IContext } from '../IContext';\nimport { IMenuModelFactory } from '../IMenuModelFactory';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-action-menu-bar\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-action-menu-bar\" [class.rendering]=\"_isRendering()\">\n\t<div *ngFor=\"let action of getActiveActionModels()\" class=\"action\">\n\t\t<phx-action-btn [model]=\"action\" *ngIf=\"isShow(action)\"></phx-action-btn>\n\t</div>\n\t<div class=\"more\">\n\t\t<phx-action-btn [model]=\"getMoreModel()\" *ngIf=\"isShowMore()\" (click)=\"onMoreBtnClicked($event)\"></phx-action-btn>\n\t</div>\n</div>\n`\n})\nexport class ActionMenuBar implements OnInit, IContext, OnDestroy {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  @Input()\n  private menuFactory: IMenuModelFactory;\n  @Input()\n  private models: ActionModel[];\n  @Input()\n  private maxWidth: number; // as pixel\n  private activeActionModels: ActionModel[];\n  private moreActionModels: ActionModel[];\n  private contextMenu: ContextMenu;\n  private menuModel: MenuModel;\n  private moreModel: ActionModel;\n  private elementRef: ElementRef;\n  private delayTimer: any;\n  private isRendering: boolean;\n  private isShowMoreMenu: boolean;\n\n  constructor(elementRef: ElementRef) {\n    this.elementRef = elementRef;\n    this.isShowMoreMenu = false;\n\n    this.moreActionModels = [];\n    this.activeActionModels = [];\n    this.isRendering = false;\n\n    let showFunction: Function = () => { return true; };\n    let enableFunction: Function = () => { return true; };\n    //        let actionPerformedHandler: Function = () => {\n    //            console.log(\"MORE\");\n    //        };\n\n    this.moreModel = new ActionModelMenu(null, \"More\", \"other\", showFunction, enableFunction, null, this.moreActionModels);\n  }\n\n  public ngOnInit(): void {\n    this.init();\n    this.reload();\n  }\n\n  public ngOnDestroy() {\n    if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {\n      this.contextMenu.setContext(null);\n    }\n  }\n\n  public init(): void {\n    if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {\n      this.contextMenu.setContext(this);\n    }\n    if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') {\n      this.menuModel = this.menuFactory.createMenuModel(this);\n    }\n    /*\n    this.activeActionModels = [];\n    if (this.models != null && typeof this.models !== 'undefined') {\n        for(let item of this.models){\n            this.activeActionModels.push(item);\n        }\n    }\n    */\n  }\n\n  private reRenderActionMenuBar(): void {\n    if (this.maxWidth !== null && typeof this.maxWidth !== 'undefined') {\n      let tempMap: any = {};\n      let allWidth: number = 0;\n\n      $(this.elementRef.nativeElement).find(\".phx-action-menu-bar >.action\").each((index: number, value: any) => {\n        let width: number = $(value).width();\n\n        allWidth += width;\n\n        let indexString: string = index + \"\";\n        tempMap[indexString] = {\n          width: width\n        };\n\n      });\n\n      // remove from actions\n      this.moreActionModels = [];\n      if (allWidth > this.maxWidth) {\n        let tempArray: any[] = [];\n        let currentWidth: number = 0;\n        for (let i = 0; i < this.activeActionModels.length; i++) {\n          let indexString: string = i + \"\";\n          let model: any = this.activeActionModels[i];\n          let width: number = 0;\n          if (tempMap[indexString] !== null && typeof tempMap[indexString] !== 'undefined') {\n            width = tempMap[indexString].width\n\n            currentWidth += width;\n          }\n          if (currentWidth > this.maxWidth) {\n            tempArray.push(model);\n          }\n        }\n\n        for (let item of tempArray) {\n          let removeIdx = this.activeActionModels.indexOf(item);\n          if (removeIdx > -1) {\n            this.activeActionModels.splice(removeIdx, 1);\n          }\n\n          this.moreActionModels.push(item);\n        }\n      }\n\n      if (this.moreModel instanceof ActionModelMenu) {\n        this.moreModel.items = this.moreActionModels;\n      }\n\n    } else {\n      // clear moreItem\n      this.moreActionModels = [];\n      \n      if (this.moreModel instanceof ActionModelMenu) {\n        this.moreModel.items = this.moreActionModels;\n      }\n    }\n  }\n\n  private getTopMoreMenu(): number {\n    let height = $(this.elementRef.nativeElement).find(\".action-menu-bar\").height();\n\n    return height - 10;\n  }\n\n  private getLeftMoreMenu(): number {\n    let position = $(this.elementRef.nativeElement).find(\".action-menu-bar >.more\").position();\n    let left = 0;\n    if (typeof position !== 'undefined') {\n      left = position.left;\n    }\n\n    return left;\n  }\n\n  private showMoreMenu(show: boolean): void {\n    this.isShowMoreMenu = show;\n  }\n\n  public _isRendering(): boolean {\n    return this.isRendering;\n  }\n\n  public onMoreBtnClicked($event: Event): void {\n    if (this.isShowMoreMenu) {\n      this.showMoreMenu(false);\n    } else {\n      this.showMoreMenu(true);\n    }\n  }\n\n  public isShow(model: ActionModel): boolean {\n    if (model.isShow === null) {\n      return false;\n    }\n    if (typeof model.isShow !== 'function') {\n      return false\n    }\n    return model.isShow(this);\n  }\n\n  public isEnabled(model: ActionModel): boolean {\n    if (model.isEnabled === null) {\n      return false;\n    }\n    if (typeof model.isEnabled !== 'function') {\n      return false\n    }\n    return model.isEnabled(this);\n  }\n\n  public isShowMore(): boolean {\n    return this.moreActionModels.length > 0 ? true : false;\n  }\n\n  public reload(): void {\n    this.activeActionModels = [];\n    if (this.models != null && typeof this.models !== 'undefined') {\n      for (let item of this.models) {\n        this.activeActionModels.push(item);\n      }\n    }\n\n    if (this.delayTimer !== null && typeof this.delayTimer !== 'undefined') {\n      clearTimeout(this.delayTimer);\n      this.delayTimer = null;\n    }\n\n    this.isRendering = true;\n    this.delayTimer = setTimeout(() => {\n      this.reRenderActionMenuBar();\n      this.isRendering = false;\n    }, 1);\n  }\n\n  public getContextMenu(): ContextMenu {\n    return this.contextMenu;\n  }\n\n  public setContextMenu(menu: ContextMenu): void {\n    this.contextMenu = menu;\n  }\n\n  public getMenuModelFactory(): IMenuModelFactory {\n    return this.menuFactory;\n  }\n\n  public setMenuModelFactory(menuFactory: IMenuModelFactory): void {\n    this.menuFactory = menuFactory;\n  }\n\n  public setMaxWidth(maxWidth: number): void {\n    this.maxWidth = maxWidth;\n\n    this.reload();\n  }\n\n  public getMoreModel(): ActionModel {\n    return this.moreModel;\n  }\n\n  public getActiveActionModels(): ActionModel[] {\n    return this.activeActionModels;\n  }\n}\n"]}