com.phloxui
Version:
PhloxUI Ng2+ Framework
380 lines (379 loc) • 29.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ElementRef, Input } from '@angular/core';
import { MenuModel } from './model/MenuModel';
import { AbstractMenu } from './AbstractMenu';
import { NeedFocusService } from '../service/NeedFocusService.service';
import { Option } from '../decorator/Option.decorator';
import { I18N } from '../decorator/I18N.decorator';
var /** @type {?} */ TYPE_NAME = "phx-context-menu";
var ContextMenu = /** @class */ (function (_super) {
tslib_1.__extends(ContextMenu, _super);
function ContextMenu(elementRef, needFocusService) {
var _this = _super.call(this, needFocusService) || this;
_this.elementRef = elementRef;
_this._show = false;
_this.autoFocus = true;
return _this;
}
/**
* @return {?}
*/
ContextMenu.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.init();
if (this.autoFocus === null || typeof this.autoFocus === 'undefined') {
this.autoFocus = true;
}
};
/**
* @return {?}
*/
ContextMenu.prototype.init = /**
* @return {?}
*/
function () {
if (this.context != null) {
this.context.setContextMenu(this);
}
if (this.nativeElement === undefined) {
// remove dom and save them in RAM
this.nativeElement = $(this.elementRef.nativeElement).detach();
}
this.showMenu(this._show);
};
/**
* @param {?} isShow
* @param {?=} widthSet
* @return {?}
*/
ContextMenu.prototype.showMenu = /**
* @param {?} isShow
* @param {?=} widthSet
* @return {?}
*/
function (isShow, widthSet) {
var _this = this;
this._show = isShow;
if (this.nativeElement === undefined) {
// remove dom and save them in RAM
this.nativeElement = $(this.elementRef.nativeElement).detach();
}
if (this._show) {
if (this.context != null && this.context.getMenuModelFactory() != null) {
this.model = this.context.getMenuModelFactory().createMenuModel(this.context);
}
if (this.needFocusService != null) {
if (this.autoFocus) {
this.needFocusService.setFocusingComponent(this);
}
}
$(this.elementRef.nativeElement).addClass('show');
setTimeout(function () {
$(_this.elementRef.nativeElement).css('opacity', 1);
// append dom
$("body").append(_this.nativeElement);
if (typeof widthSet !== "number") {
var /** @type {?} */ left = $(_this.elementRef.nativeElement).offset().left;
var /** @type {?} */ width = $(_this.elementRef.nativeElement).width();
$(_this.nativeElement).css('left', (left - width) + "px");
}
}, 1);
}
else {
$(this.elementRef.nativeElement).removeClass('show');
$(this.elementRef.nativeElement).css('opacity', 0);
if (this.needFocusService != null) {
if (this.autoFocus && this.needFocusService.getFocusingComponent() === this) {
this.needFocusService.resetFocusingComponent();
}
}
}
};
/**
* @param {?} positionX
* @param {?} positionY
* @param {?=} width
* @return {?}
*/
ContextMenu.prototype.showAt = /**
* @param {?} positionX
* @param {?} positionY
* @param {?=} width
* @return {?}
*/
function (positionX, positionY, width) {
if (positionX == null && positionY == null) {
return;
}
if (positionX == null) {
positionX = 0;
}
if (positionY == null) {
positionY = 0;
}
if (this.nativeElement === undefined) {
// remove dom and save them in RAM
this.nativeElement = $(this.elementRef.nativeElement).detach();
}
$(this.nativeElement).css('top', positionX + "px");
$(this.nativeElement).css('left', positionY + "px");
if (width !== null && width !== undefined) {
$(this.nativeElement).css('width', width);
}
this.showMenu(true, width);
};
/**
* @return {?}
*/
ContextMenu.prototype.hide = /**
* @return {?}
*/
function () {
this.showMenu(false);
};
/**
* @param {?} $event
* @return {?}
*/
ContextMenu.prototype.onItemClick = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (this.autoFocus) {
if (this.needFocusService !== null && this.needFocusService !== undefined) {
this.needFocusService.setFocusingComponent(this);
}
}
};
/**
* @return {?}
*/
ContextMenu.prototype.isShow = /**
* @return {?}
*/
function () {
return this._show;
};
/**
* @return {?}
*/
ContextMenu.prototype.doRenderMenu = /**
* @return {?}
*/
function () {
// all item was cleared and items should be set here
};
/**
* @param {?} dataParent
* @return {?}
*/
ContextMenu.prototype.setDataParent = /**
* @param {?} dataParent
* @return {?}
*/
function (dataParent) {
this.dataParent = dataParent;
};
/**
* @return {?}
*/
ContextMenu.prototype.getDataParent = /**
* @return {?}
*/
function () {
return this.dataParent;
};
/**
* @return {?}
*/
ContextMenu.prototype.getContext = /**
* @return {?}
*/
function () {
return this.context;
};
/**
* @param {?} context
* @return {?}
*/
ContextMenu.prototype.setContext = /**
* @param {?} context
* @return {?}
*/
function (context) {
this.context = context;
};
/**
* @param {?} event
* @return {?}
*/
ContextMenu.prototype.onFocus = /**
* @param {?} event
* @return {?}
*/
function (event) {
var _this = this;
if (this.focusTimeout !== undefined && this.focusTimeout !== null) {
clearTimeout(this.focusTimeout);
}
this.focusTimeout = setTimeout(function () {
$(_this.elementRef.nativeElement).find(".fake").focus();
}, 20);
};
/**
* @param {?} event
* @return {?}
*/
ContextMenu.prototype.onLostFocus = /**
* @param {?} event
* @return {?}
*/
function (event) {
var _this = this;
if (this.lostFocusTimeout !== undefined && this.lostFocusTimeout !== null) {
clearTimeout(this.lostFocusTimeout);
}
this.lostFocusTimeout = setTimeout(function () {
_this.showMenu(false);
$(_this.elementRef.nativeElement).find(".fake").blur();
}, 400);
};
/**
* @param {?} autoFocus
* @return {?}
*/
ContextMenu.prototype.setAutoFocus = /**
* @param {?} autoFocus
* @return {?}
*/
function (autoFocus) {
this.autoFocus = autoFocus;
};
/**
* @return {?}
*/
ContextMenu.prototype.isAutoFocus = /**
* @return {?}
*/
function () {
return this.autoFocus;
};
/**
* @param {?} $event
* @return {?}
*/
ContextMenu.prototype._doFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
// do something when focus
if (this.needFocusService !== null && this.needFocusService !== undefined) {
this.needFocusService.setFocusingComponent(this);
}
};
/**
* @param {?} $event
* @return {?}
*/
ContextMenu.prototype._doLostFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (this.needFocusService !== null && this.needFocusService.getFocusingComponent() === this) {
this.needFocusService.resetFocusingComponent();
}
};
ContextMenu.TYPE_NAME = TYPE_NAME;
ContextMenu.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"phx-context-menu\">\n\t<ul *ngIf=\"getModel() != null\">\n\t\t<li *ngFor=\"let item of getModel().items; let i = index\" [class.disable]=\"!item.enable\" (click)=\"onItemClick($event)\"><phx-component-wrapper\n\t\t\t\t[type]=\"item.type\" [handler]=\"getMenuItemHandler()\" [model]=\"item\"\n\t\t\t\t[class.disable]=\"!item.enable\"></phx-component-wrapper></li>\n\t</ul>\n\t<button type=\"button\" class=\"fake\" (focusin)=\"_doFocus($event)\" (blur)=\"_doLostFocus($event)\"></button>\n</div>\n"
},] },
];
/** @nocollapse */
ContextMenu.ctorParameters = function () { return [
{ type: ElementRef, },
{ type: NeedFocusService, },
]; };
ContextMenu.propDecorators = {
"model": [{ type: Input },],
"items": [{ type: Input },],
"dataParent": [{ type: Input },],
"context": [{ type: Input },],
"autoFocus": [{ type: Input },],
};
tslib_1.__decorate([
Option(),
I18N(),
tslib_1.__metadata("design:type", MenuModel)
], ContextMenu.prototype, "model", void 0);
tslib_1.__decorate([
Option(),
I18N(),
tslib_1.__metadata("design:type", Array)
], ContextMenu.prototype, "items", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], ContextMenu.prototype, "dataParent", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], ContextMenu.prototype, "context", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], ContextMenu.prototype, "autoFocus", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], ContextMenu.prototype, "menuItemHandler", void 0);
return ContextMenu;
}(AbstractMenu));
export { ContextMenu };
function ContextMenu_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
ContextMenu.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
ContextMenu.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
ContextMenu.propDecorators;
/** @type {?} */
ContextMenu.TYPE_NAME;
/** @type {?} */
ContextMenu.prototype.model;
/** @type {?} */
ContextMenu.prototype.items;
/** @type {?} */
ContextMenu.prototype.dataParent;
/** @type {?} */
ContextMenu.prototype.context;
/** @type {?} */
ContextMenu.prototype.autoFocus;
/** @type {?} */
ContextMenu.prototype.menuItemHandler;
/** @type {?} */
ContextMenu.prototype.elementRef;
/** @type {?} */
ContextMenu.prototype._show;
/** @type {?} */
ContextMenu.prototype.nativeElement;
/** @type {?} */
ContextMenu.prototype.focusTimeout;
/** @type {?} */
ContextMenu.prototype.lostFocusTimeout;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ContextMenu.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/ContextMenu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, HostListener } from '@angular/core';\nimport { MenuModel } from './model/MenuModel';\nimport { MenuItemModel } from './model/MenuItemModel';\nimport { AbstractMenu } from './AbstractMenu';\nimport { IHasContext } from './IHasContext';\nimport { IContext } from './IContext';\nimport { INeedFocus } from './INeedFocus';\nimport { IHasDataParent } from './IHasDataParent';\nimport { IHasData } from './IHasData';\nimport { NeedFocusService } from '../service/NeedFocusService.service';\nimport { AbstractMenuItem } from './AbstractMenuItem';\nimport { Option } from '../decorator/Option.decorator';\nimport { I18N } from '../decorator/I18N.decorator';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-context-menu\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-context-menu\">\n\t<ul *ngIf=\"getModel() != null\">\n\t\t<li *ngFor=\"let item of getModel().items; let i = index\" [class.disable]=\"!item.enable\" (click)=\"onItemClick($event)\"><phx-component-wrapper\n\t\t\t\t[type]=\"item.type\" [handler]=\"getMenuItemHandler()\" [model]=\"item\"\n\t\t\t\t[class.disable]=\"!item.enable\"></phx-component-wrapper></li>\n\t</ul>\n\t<button type=\"button\" class=\"fake\" (focusin)=\"_doFocus($event)\" (blur)=\"_doLostFocus($event)\"></button>\n</div>\n`\n})\nexport class ContextMenu extends AbstractMenu implements OnInit, IHasContext, INeedFocus, IHasDataParent {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  // Re-declare field to declare ng @Input.\n  // --- from AbstractMenu\n  @Input()\n  @Option()\n  @I18N()\n  protected model: MenuModel;\n  @Input()\n  @Option()\n  @I18N()\n  protected items: AbstractMenuItem[];\n  // --- self\n  @Input()\n  @Option()\n  protected dataParent: IHasData;\n  @Input()\n  @Option()\n  private context: IContext;\n  @Input()\n  @Option()\n  private autoFocus: boolean;\n\n  // Re-declare field to declare ng @Output.\n  // Re-declare field to declare\n  // --- from AbstractMenu\n  @Option()\n  protected menuItemHandler: Function;\n\n  // --- self\n  protected elementRef: ElementRef;\n  private _show: boolean;\n  private nativeElement: any;\n  private focusTimeout: any;\n  private lostFocusTimeout: any;\n\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService) {\n    super(needFocusService);\n    this.elementRef = elementRef;\n    this._show = false;\n    this.autoFocus = true;\n  }\n\n  public ngOnInit(): void {\n    this.init();\n\n    if (this.autoFocus === null || typeof this.autoFocus === 'undefined') {\n      this.autoFocus = true;\n    }\n\n  }\n\n  private init(): void {\n    if (this.context != null) {\n      this.context.setContextMenu(this);\n    }\n\n    if (this.nativeElement === undefined) {\n      // remove dom and save them in RAM\n      this.nativeElement = $(this.elementRef.nativeElement).detach();\n    }\n\n    this.showMenu(this._show);\n  }\n\n  private showMenu(isShow: boolean, widthSet?: number): void {\n    this._show = isShow;\n\n    if (this.nativeElement === undefined) {\n      // remove dom and save them in RAM\n      this.nativeElement = $(this.elementRef.nativeElement).detach();\n    }\n\n    if (this._show) {\n      if (this.context != null && this.context.getMenuModelFactory() != null) {\n        this.model = this.context.getMenuModelFactory().createMenuModel(this.context);\n      }\n\n      if (this.needFocusService != null) {\n        if (this.autoFocus) {\n          this.needFocusService.setFocusingComponent(this);\n        }\n      }\n\n      $(this.elementRef.nativeElement).addClass('show');\n      setTimeout(() => {\n        $(this.elementRef.nativeElement).css('opacity', 1);\n        // append dom\n        $(\"body\").append(this.nativeElement);\n        if (typeof widthSet !== \"number\") {\n          let left = $(this.elementRef.nativeElement).offset().left;\n          let width = $(this.elementRef.nativeElement).width();\n          $(this.nativeElement).css('left', (left - width) + \"px\");\n        }\n      }, 1);\n    } else {\n      $(this.elementRef.nativeElement).removeClass('show');\n      $(this.elementRef.nativeElement).css('opacity', 0);\n\n      if (this.needFocusService != null) {\n        if (this.autoFocus && this.needFocusService.getFocusingComponent() === this) {\n          this.needFocusService.resetFocusingComponent();\n        }\n      }\n    }\n  }\n\n  public showAt(positionX: number, positionY: number, width?: number): void {\n    if (positionX == null && positionY == null) {\n      return;\n    }\n    if (positionX == null) {\n      positionX = 0;\n    }\n    if (positionY == null) {\n      positionY = 0;\n    }\n\n    if (this.nativeElement === undefined) {\n      // remove dom and save them in RAM\n      this.nativeElement = $(this.elementRef.nativeElement).detach();\n    }\n\n    $(this.nativeElement).css('top', positionX + \"px\");\n    $(this.nativeElement).css('left', positionY + \"px\");\n\n    if (width !== null && width !== undefined) {\n      $(this.nativeElement).css('width', width);\n    }\n\n    this.showMenu(true, width);\n  }\n\n  public hide(): void {\n    this.showMenu(false);\n  }\n\n  public onItemClick($event: Event): void {\n    if (this.autoFocus) {\n      if (this.needFocusService !== null && this.needFocusService !== undefined) {\n        this.needFocusService.setFocusingComponent(this);\n      }\n    }\n  }\n\n  public isShow(): boolean {\n    return this._show;\n  }\n\n  public doRenderMenu(): void {\n    // all item was cleared and items should be set here\n  }\n\n  public setDataParent(dataParent: IHasData) {\n    this.dataParent = dataParent;\n  }\n\n  public getDataParent(): IHasData {\n    return this.dataParent;\n  }\n\n  public getContext(): IContext {\n    return this.context;\n  }\n\n  public setContext(context: IContext): void {\n    this.context = context;\n  }\n\n  public onFocus(event: any): void {\n    if (this.focusTimeout !== undefined && this.focusTimeout !== null) {\n      clearTimeout(this.focusTimeout);\n    }\n\n    this.focusTimeout = setTimeout(() => {\n      $(this.elementRef.nativeElement).find(\".fake\").focus();\n    }, 20);\n  }\n\n  public onLostFocus(event: any): void {\n    if (this.lostFocusTimeout !== undefined && this.lostFocusTimeout !== null) {\n      clearTimeout(this.lostFocusTimeout);\n    }\n\n    this.lostFocusTimeout = setTimeout(() => {\n      this.showMenu(false);\n      $(this.elementRef.nativeElement).find(\".fake\").blur();\n    }, 400);\n  }\n\n  public setAutoFocus(autoFocus: boolean): void {\n    this.autoFocus = autoFocus;\n  }\n\n  public isAutoFocus(): boolean {\n    return this.autoFocus;\n  }\n\n  public _doFocus($event: Event): void {\n    // do something when focus\n    if (this.needFocusService !== null && this.needFocusService !== undefined) {\n      this.needFocusService.setFocusingComponent(this);\n    }\n  }\n\n  public _doLostFocus($event: Event): void {\n    if (this.needFocusService !== null && this.needFocusService.getFocusingComponent() === this) {\n      this.needFocusService.resetFocusingComponent();\n    }\n  }\n}\n"]}