com.phloxui
Version:
PhloxUI Ng2+ Framework
318 lines (317 loc) • 27 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';
const /** @type {?} */ TYPE_NAME = "phx-context-menu";
export class ContextMenu extends AbstractMenu {
/**
* @param {?} elementRef
* @param {?} needFocusService
*/
constructor(elementRef, needFocusService) {
super(needFocusService);
this.elementRef = elementRef;
this._show = false;
this.autoFocus = true;
}
/**
* @return {?}
*/
ngOnInit() {
this.init();
if (this.autoFocus === null || typeof this.autoFocus === 'undefined') {
this.autoFocus = true;
}
}
/**
* @return {?}
*/
init() {
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 {?}
*/
showMenu(isShow, widthSet) {
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(() => {
$(this.elementRef.nativeElement).css('opacity', 1);
// append dom
$("body").append(this.nativeElement);
if (typeof widthSet !== "number") {
let /** @type {?} */ left = $(this.elementRef.nativeElement).offset().left;
let /** @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 {?}
*/
showAt(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 {?}
*/
hide() {
this.showMenu(false);
}
/**
* @param {?} $event
* @return {?}
*/
onItemClick($event) {
if (this.autoFocus) {
if (this.needFocusService !== null && this.needFocusService !== undefined) {
this.needFocusService.setFocusingComponent(this);
}
}
}
/**
* @return {?}
*/
isShow() {
return this._show;
}
/**
* @return {?}
*/
doRenderMenu() {
// all item was cleared and items should be set here
}
/**
* @param {?} dataParent
* @return {?}
*/
setDataParent(dataParent) {
this.dataParent = dataParent;
}
/**
* @return {?}
*/
getDataParent() {
return this.dataParent;
}
/**
* @return {?}
*/
getContext() {
return this.context;
}
/**
* @param {?} context
* @return {?}
*/
setContext(context) {
this.context = context;
}
/**
* @param {?} event
* @return {?}
*/
onFocus(event) {
if (this.focusTimeout !== undefined && this.focusTimeout !== null) {
clearTimeout(this.focusTimeout);
}
this.focusTimeout = setTimeout(() => {
$(this.elementRef.nativeElement).find(".fake").focus();
}, 20);
}
/**
* @param {?} event
* @return {?}
*/
onLostFocus(event) {
if (this.lostFocusTimeout !== undefined && this.lostFocusTimeout !== null) {
clearTimeout(this.lostFocusTimeout);
}
this.lostFocusTimeout = setTimeout(() => {
this.showMenu(false);
$(this.elementRef.nativeElement).find(".fake").blur();
}, 400);
}
/**
* @param {?} autoFocus
* @return {?}
*/
setAutoFocus(autoFocus) {
this.autoFocus = autoFocus;
}
/**
* @return {?}
*/
isAutoFocus() {
return this.autoFocus;
}
/**
* @param {?} $event
* @return {?}
*/
_doFocus($event) {
// do something when focus
if (this.needFocusService !== null && this.needFocusService !== undefined) {
this.needFocusService.setFocusingComponent(this);
}
}
/**
* @param {?} $event
* @return {?}
*/
_doLostFocus($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">
<ul *ngIf="getModel() != null">
<li *ngFor="let item of getModel().items; let i = index" [class.disable]="!item.enable" (click)="onItemClick($event)"><phx-component-wrapper
[type]="item.type" [handler]="getMenuItemHandler()" [model]="item"
[class.disable]="!item.enable"></phx-component-wrapper></li>
</ul>
<button type="button" class="fake" (focusin)="_doFocus($event)" (blur)="_doLostFocus($event)"></button>
</div>
`
},] },
];
/** @nocollapse */
ContextMenu.ctorParameters = () => [
{ 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);
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"]}