com.phloxui
Version:
PhloxUI Ng2+ Framework
398 lines (397 loc) • 30 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, Input, ElementRef } 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 () {
var _this = this;
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(function () {
_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;
};
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"
},] },
];
/** @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/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"]}