com.phloxui
Version:
PhloxUI Ng2+ Framework
331 lines (330 loc) • 27.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import { Component, Input, ElementRef, ChangeDetectionStrategy } 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;
}
/**
* @return {?}
*/
getModels() {
return this.models;
}
/**
* @param {?} models
* @return {?}
*/
setModels(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()">
<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>
`,
changeDetection: ChangeDetectionStrategy.Default
},] },
];
/** @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/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"]}