UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

419 lines (418 loc) 30.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, ElementRef, ChangeDetectionStrategy } from '@angular/core'; import { ActionModelMenu } from '../../model/ActionModelMenu'; var /** @type {?} */ TYPE_NAME = "phx-action-menu-bar"; var ActionMenuBar = /** @class */ (function () { function ActionMenuBar(elementRef) { this.elementRef = elementRef; this.isShowMoreMenu = false; this.moreActionModels = []; this.activeActionModels = []; this.isRendering = false; var /** @type {?} */ showFunction = function () { return true; }; var /** @type {?} */ enableFunction = function () { return true; }; // let actionPerformedHandler: Function = () => { // console.log("MORE"); // }; this.moreModel = new ActionModelMenu(null, "More", "other", showFunction, enableFunction, null, this.moreActionModels); } /** * @return {?} */ ActionMenuBar.prototype.ngOnInit = /** * @return {?} */ function () { this.init(); this.reload(); }; /** * @return {?} */ ActionMenuBar.prototype.ngOnDestroy = /** * @return {?} */ function () { if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') { this.contextMenu.setContext(null); } }; /** * @return {?} */ ActionMenuBar.prototype.init = /** * @return {?} */ function () { 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 {?} */ ActionMenuBar.prototype.reRenderActionMenuBar = /** * @return {?} */ function () { if (this.maxWidth !== null && typeof this.maxWidth !== 'undefined') { var /** @type {?} */ tempMap_1 = {}; var /** @type {?} */ allWidth_1 = 0; $(this.elementRef.nativeElement).find(".phx-action-menu-bar >.action").each(function (index, value) { var /** @type {?} */ width = $(value).width(); allWidth_1 += width; var /** @type {?} */ indexString = index + ""; tempMap_1[indexString] = { width: width }; }); // remove from actions this.moreActionModels = []; if (allWidth_1 > this.maxWidth) { var /** @type {?} */ tempArray = []; var /** @type {?} */ currentWidth = 0; for (var /** @type {?} */ i = 0; i < this.activeActionModels.length; i++) { var /** @type {?} */ indexString = i + ""; var /** @type {?} */ model = this.activeActionModels[i]; var /** @type {?} */ width = 0; if (tempMap_1[indexString] !== null && typeof tempMap_1[indexString] !== 'undefined') { width = tempMap_1[indexString].width; currentWidth += width; } if (currentWidth > this.maxWidth) { tempArray.push(model); } } try { for (var tempArray_1 = tslib_1.__values(tempArray), tempArray_1_1 = tempArray_1.next(); !tempArray_1_1.done; tempArray_1_1 = tempArray_1.next()) { var item = tempArray_1_1.value; var /** @type {?} */ removeIdx = this.activeActionModels.indexOf(item); if (removeIdx > -1) { this.activeActionModels.splice(removeIdx, 1); } this.moreActionModels.push(item); } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (tempArray_1_1 && !tempArray_1_1.done && (_a = tempArray_1.return)) _a.call(tempArray_1); } finally { if (e_1) throw e_1.error; } } } 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; } } var e_1, _a; }; /** * @return {?} */ ActionMenuBar.prototype.getTopMoreMenu = /** * @return {?} */ function () { var /** @type {?} */ height = $(this.elementRef.nativeElement).find(".action-menu-bar").height(); return height - 10; }; /** * @return {?} */ ActionMenuBar.prototype.getLeftMoreMenu = /** * @return {?} */ function () { var /** @type {?} */ position = $(this.elementRef.nativeElement).find(".action-menu-bar >.more").position(); var /** @type {?} */ left = 0; if (typeof position !== 'undefined') { left = position.left; } return left; }; /** * @param {?} show * @return {?} */ ActionMenuBar.prototype.showMoreMenu = /** * @param {?} show * @return {?} */ function (show) { this.isShowMoreMenu = show; }; /** * @return {?} */ ActionMenuBar.prototype._isRendering = /** * @return {?} */ function () { return this.isRendering; }; /** * @param {?} $event * @return {?} */ ActionMenuBar.prototype.onMoreBtnClicked = /** * @param {?} $event * @return {?} */ function ($event) { if (this.isShowMoreMenu) { this.showMoreMenu(false); } else { this.showMoreMenu(true); } }; /** * @param {?} model * @return {?} */ ActionMenuBar.prototype.isShow = /** * @param {?} model * @return {?} */ function (model) { if (model.isShow === null) { return false; } if (typeof model.isShow !== 'function') { return false; } return model.isShow(this); }; /** * @param {?} model * @return {?} */ ActionMenuBar.prototype.isEnabled = /** * @param {?} model * @return {?} */ function (model) { if (model.isEnabled === null) { return false; } if (typeof model.isEnabled !== 'function') { return false; } return model.isEnabled(this); }; /** * @return {?} */ ActionMenuBar.prototype.isShowMore = /** * @return {?} */ function () { return this.moreActionModels.length > 0 ? true : false; }; /** * @return {?} */ ActionMenuBar.prototype.reload = /** * @return {?} */ function () { this.activeActionModels = []; if (this.models != null && typeof this.models !== 'undefined') { try { for (var _a = tslib_1.__values(this.models), _b = _a.next(); !_b.done; _b = _a.next()) { var item = _b.value; this.activeActionModels.push(item); } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (_b && !_b.done && (_c = _a.return)) _c.call(_a); } finally { if (e_2) throw e_2.error; } } } // 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); var e_2, _c; }; /** * @return {?} */ ActionMenuBar.prototype.getContextMenu = /** * @return {?} */ function () { return this.contextMenu; }; /** * @param {?} menu * @return {?} */ ActionMenuBar.prototype.setContextMenu = /** * @param {?} menu * @return {?} */ function (menu) { this.contextMenu = menu; }; /** * @return {?} */ ActionMenuBar.prototype.getMenuModelFactory = /** * @return {?} */ function () { return this.menuFactory; }; /** * @param {?} menuFactory * @return {?} */ ActionMenuBar.prototype.setMenuModelFactory = /** * @param {?} menuFactory * @return {?} */ function (menuFactory) { this.menuFactory = menuFactory; }; /** * @param {?} maxWidth * @return {?} */ ActionMenuBar.prototype.setMaxWidth = /** * @param {?} maxWidth * @return {?} */ function (maxWidth) { this.maxWidth = maxWidth; this.reload(); }; /** * @return {?} */ ActionMenuBar.prototype.getMoreModel = /** * @return {?} */ function () { return this.moreModel; }; /** * @return {?} */ ActionMenuBar.prototype.getActiveActionModels = /** * @return {?} */ function () { return this.activeActionModels; }; /** * @return {?} */ ActionMenuBar.prototype.getModels = /** * @return {?} */ function () { return this.models; }; /** * @param {?} models * @return {?} */ ActionMenuBar.prototype.setModels = /** * @param {?} models * @return {?} */ function (models) { this.models = models; this.reload(); }; 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()\">\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", changeDetection: ChangeDetectionStrategy.Default },] }, ]; /** @nocollapse */ ActionMenuBar.ctorParameters = function () { return [ { type: ElementRef, }, ]; }; ActionMenuBar.propDecorators = { "menuFactory": [{ type: Input },], "models": [{ type: Input },], "maxWidth": [{ type: Input },], }; return ActionMenuBar; }()); export { ActionMenuBar }; 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/editor.internal/ActionMenuBar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, ElementRef, OnDestroy, ChangeDetectionStrategy } 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  changeDetection: ChangeDetectionStrategy.Default\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  public 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  public getModels(): ActionModel[] {\n    return this.models;\n  }\n\n  public setModels(models: ActionModel[]): void {\n    this.models = models;\n\n    this.reload();\n  }\n}\n"]}