com.phloxui
Version:
PhloxUI Ng2+ Framework
401 lines (400 loc) • 29.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ElementRef, Input, Output, EventEmitter } from '@angular/core';
import { MenuModel } from './model/models';
import { AbstractHasData } from './AbstractHasData';
import { Option } from '../decorator/Option.decorator';
import { I18N } from '../decorator/I18N.decorator';
import { NeedFocusService } from '../service/NeedFocusService.service';
const /** @type {?} */ TYPE_NAME = "phx-context-menu-btn";
const /** @type {?} */ TYPE_PARENT = "parent";
const /** @type {?} */ TYPE_CHILDREN = "children";
const /** @type {?} */ TYPE_DISTANCE = "distance";
export class ContextMenuButton extends AbstractHasData {
/**
* @param {?} elementRef
* @param {?} needFocusService
*/
constructor(elementRef, needFocusService) {
super(elementRef);
this.needFocusService = needFocusService;
this.autoFocus = true;
}
/**
* @return {?}
*/
ngOnInit() {
this.init();
}
/**
* @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);
}
}
/**
* @return {?}
*/
recreateMenuModel() {
this.menuModel = this.menuFactory.createMenuModel(this);
}
/**
* @param {?} $event
* @return {?}
*/
onMoreButtonClick($event) {
if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') {
if (this.contextMenu.isShow()) {
setTimeout(() => {
this.hideMenu();
}, 50);
}
else {
let /** @type {?} */ anchorEl = this.elementRef.nativeElement;
if (this.anchorComponent !== null && this.anchorComponent !== undefined) {
anchorEl = this.anchorComponent.elementRef.nativeElement;
}
else if (this.anchorSelector !== null && typeof this.anchorSelector === 'string') {
let /** @type {?} */ selector = $(this.anchorSelector);
if (selector.length > 0) {
anchorEl = selector[0];
}
}
let /** @type {?} */ offsetTop = 0;
let /** @type {?} */ offsetLeft = 0;
if (this.menuOffsetTop !== null && typeof this.menuOffsetTop === 'number') {
offsetTop = this.menuOffsetTop;
}
if (this.menuOffsetLeft !== null && typeof this.menuOffsetLeft === 'number') {
offsetLeft = this.menuOffsetLeft;
}
let /** @type {?} */ top = $(anchorEl).offset().top + $(anchorEl).height() + offsetTop;
let /** @type {?} */ leftEllipsisButton = $(this.elementRef.nativeElement).offset().left + offsetLeft;
let /** @type {?} */ widthEllipsisButton = $(this.elementRef.nativeElement).outerWidth();
let /** @type {?} */ setLeft = leftEllipsisButton + widthEllipsisButton;
this.contextMenu.showAt(top, setLeft);
}
}
}
/**
* @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;
}
/**
* @return {?}
*/
getMenuModel() {
return this.menuModel;
}
/**
* @return {?}
*/
isSelfDataDirty() {
return false;
}
/**
* @param {?} data
* @return {?}
*/
selfSaveData(data) {
}
/**
* @return {?}
*/
selfResetData() {
}
/**
* @return {?}
*/
doPreload() { return new Promise((resolve, reject) => { resolve(null); }); }
/**
* @return {?}
*/
doLoaded() {
}
/**
* @return {?}
*/
isIconURLEmpty() {
if (this.iconURL == null || this.iconURL === undefined) {
return true;
}
return false;
}
/**
* @return {?}
*/
getIconURL() {
return this.iconURL;
}
/**
* @return {?}
*/
getStyleClasses() {
return this.styleClasses;
}
/**
* @return {?}
*/
hideMenu() {
if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {
this.contextMenu.hide();
}
}
/**
* @return {?}
*/
isShowMenu() {
return this.contextMenu.isShow();
}
/**
* @return {?}
*/
isAutoFocus() {
return this.autoFocus;
}
/**
* @param {?} event
* @return {?}
*/
onFocus(event) {
}
/**
* @param {?} event
* @return {?}
*/
onLostFocus(event) {
this.hideMenu();
}
/**
* @param {?} $event
* @return {?}
*/
_doFocus($event) {
// do something when focus
}
/**
* @param {?} $event
* @return {?}
*/
_doLostFocus($event) {
if (this.needFocusService !== null) {
this.needFocusService.resetFocusingComponent(this);
}
}
}
ContextMenuButton.TYPE_NAME = TYPE_NAME;
ContextMenuButton.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: `<div class="phx-context-menu-btn" [ngClass]="getStyleClasses()" (click)="onMoreButtonClick($event)">
<div class="icon-img" *ngIf="!isIconURLEmpty()">
<img src="{{getIconURL()}}">
</div>
<button type="button" class="fake" (focusin)="_doFocus($event)" (blur)="_doLostFocus($event)"></button>
</div>
<phx-context-menu [model]="getMenuModel()" [context]="this" class="vertical" [autoFocus]="isAutoFocus()"></phx-context-menu>
`
},] },
];
/** @nocollapse */
ContextMenuButton.ctorParameters = () => [
{ type: ElementRef, },
{ type: NeedFocusService, },
];
ContextMenuButton.propDecorators = {
"dataParent": [{ type: Input },],
"ignoreParentData": [{ type: Input },],
"data": [{ type: Input },],
"ignoreParentDisabled": [{ type: Input },],
"delegateHistory": [{ type: Input },],
"onDisabled": [{ type: Input },],
"onEnabled": [{ type: Input },],
"loadingEnabled": [{ type: Input },],
"i18nKey": [{ type: Input },],
"bypass": [{ type: Input, args: ['i18nBypass',] },],
"options": [{ type: Input },],
"disabled": [{ type: Input },],
"menuFactory": [{ type: Input },],
"iconURL": [{ type: Input }, { type: Output },],
"styleClasses": [{ type: Input }, { type: Output },],
"anchorComponent": [{ type: Input },],
"anchorSelector": [{ type: Input },],
"menuOffsetTop": [{ type: Input },],
"menuOffsetLeft": [{ type: Input },],
"loadEvent": [{ type: Output, args: ['phxLoad',] },],
};
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], ContextMenuButton.prototype, "dataParent", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], ContextMenuButton.prototype, "ignoreParentData", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], ContextMenuButton.prototype, "data", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], ContextMenuButton.prototype, "ignoreParentDisabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], ContextMenuButton.prototype, "delegateHistory", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], ContextMenuButton.prototype, "onDisabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], ContextMenuButton.prototype, "onEnabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], ContextMenuButton.prototype, "loadingEnabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], ContextMenuButton.prototype, "i18nKey", void 0);
tslib_1.__decorate([
Option('i18nBypass'),
tslib_1.__metadata("design:type", Boolean)
], ContextMenuButton.prototype, "bypass", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], ContextMenuButton.prototype, "disabled", void 0);
tslib_1.__decorate([
I18N(),
Option(),
tslib_1.__metadata("design:type", Object)
], ContextMenuButton.prototype, "menuFactory", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], ContextMenuButton.prototype, "anchorComponent", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], ContextMenuButton.prototype, "anchorSelector", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], ContextMenuButton.prototype, "menuOffsetTop", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], ContextMenuButton.prototype, "menuOffsetLeft", void 0);
tslib_1.__decorate([
Option('load'),
tslib_1.__metadata("design:type", EventEmitter)
], ContextMenuButton.prototype, "loadEvent", void 0);
tslib_1.__decorate([
I18N(),
tslib_1.__metadata("design:type", MenuModel)
], ContextMenuButton.prototype, "menuModel", void 0);
function ContextMenuButton_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
ContextMenuButton.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
ContextMenuButton.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
ContextMenuButton.propDecorators;
/** @type {?} */
ContextMenuButton.TYPE_NAME;
/** @type {?} */
ContextMenuButton.prototype.dataParent;
/** @type {?} */
ContextMenuButton.prototype.ignoreParentData;
/** @type {?} */
ContextMenuButton.prototype.data;
/** @type {?} */
ContextMenuButton.prototype.ignoreParentDisabled;
/** @type {?} */
ContextMenuButton.prototype.delegateHistory;
/** @type {?} */
ContextMenuButton.prototype.onDisabled;
/** @type {?} */
ContextMenuButton.prototype.onEnabled;
/** @type {?} */
ContextMenuButton.prototype.loadingEnabled;
/** @type {?} */
ContextMenuButton.prototype.i18nKey;
/** @type {?} */
ContextMenuButton.prototype.bypass;
/** @type {?} */
ContextMenuButton.prototype.options;
/** @type {?} */
ContextMenuButton.prototype.disabled;
/** @type {?} */
ContextMenuButton.prototype.menuFactory;
/** @type {?} */
ContextMenuButton.prototype.iconURL;
/** @type {?} */
ContextMenuButton.prototype.styleClasses;
/** @type {?} */
ContextMenuButton.prototype.anchorComponent;
/** @type {?} */
ContextMenuButton.prototype.anchorSelector;
/** @type {?} */
ContextMenuButton.prototype.menuOffsetTop;
/** @type {?} */
ContextMenuButton.prototype.menuOffsetLeft;
/** @type {?} */
ContextMenuButton.prototype.loadEvent;
/** @type {?} */
ContextMenuButton.prototype.menuModel;
/** @type {?} */
ContextMenuButton.prototype.contextMenu;
/** @type {?} */
ContextMenuButton.prototype.needFocusService;
/** @type {?} */
ContextMenuButton.prototype.autoFocus;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ContextMenuButton.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/ContextMenuButton.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, Output, OnDestroy, EventEmitter } from '@angular/core';\r\nimport { MenuModel } from './model/models';\r\nimport { ContextMenu } from './ContextMenu.component';\r\nimport { IContext } from './IContext';\r\nimport { IHasData } from './IHasData';\r\nimport { INeedFocus } from './INeedFocus';\r\nimport { IMenuModelFactory } from './IMenuModelFactory';\r\nimport { AbstractHasData } from './AbstractHasData';\r\nimport { Option } from '../decorator/Option.decorator';\r\nimport { I18N } from '../decorator/I18N.decorator';\r\nimport { NeedFocusService } from '../service/NeedFocusService.service';\r\n\r\ndeclare var $: any;\r\n\r\nconst TYPE_NAME: string = \"phx-context-menu-btn\";\r\n\r\nconst TYPE_PARENT = \"parent\";\r\nconst TYPE_CHILDREN = \"children\";\r\nconst TYPE_DISTANCE = \"distance\";\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: TYPE_NAME,\r\n  template: `<div class=\"phx-context-menu-btn\" [ngClass]=\"getStyleClasses()\" (click)=\"onMoreButtonClick($event)\">\r\n  <div class=\"icon-img\" *ngIf=\"!isIconURLEmpty()\">\r\n    <img src=\"{{getIconURL()}}\">\r\n  </div>\r\n  <button type=\"button\" class=\"fake\" (focusin)=\"_doFocus($event)\" (blur)=\"_doLostFocus($event)\"></button>\r\n</div>\r\n<phx-context-menu [model]=\"getMenuModel()\" [context]=\"this\" class=\"vertical\" [autoFocus]=\"isAutoFocus()\"></phx-context-menu>\r\n`\r\n})\r\nexport class ContextMenuButton extends AbstractHasData implements OnInit, IContext, OnDestroy, INeedFocus {\r\n\r\n  public static readonly TYPE_NAME: string = TYPE_NAME;\r\n\r\n  // Re-declare field to declare ng @Input.\r\n  // --- from AbstractHasData\r\n  @Input()\r\n  @Option()\r\n  protected dataParent: IHasData;\r\n  @Input()\r\n  @Option()\r\n  protected ignoreParentData: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected data: any;\r\n  @Input()\r\n  @Option()\r\n  protected ignoreParentDisabled: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected delegateHistory: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected onDisabled: Function;\r\n  @Input()\r\n  @Option()\r\n  protected onEnabled: Function;\r\n  @Input()\r\n  @Option()\r\n  protected loadingEnabled: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected i18nKey: string;\r\n  @Input('i18nBypass')\r\n  @Option('i18nBypass')\r\n  protected bypass: boolean;\r\n  @Input()\r\n  protected options: any;\r\n  @Input()\r\n  @Option()\r\n  protected disabled: boolean;\r\n\r\n  // --- from Self\r\n  @Input()\r\n  @I18N()\r\n  @Option()\r\n  protected menuFactory: IMenuModelFactory;\r\n\r\n  @Input()\r\n  @Output()\r\n  private iconURL: string;\r\n  @Input()\r\n  @Output()\r\n  private styleClasses: string[];\r\n  @Input()\r\n  @Option()\r\n  private anchorComponent: any;\r\n  @Input()\r\n  @Option()\r\n  private anchorSelector: string;\r\n  @Input()\r\n  @Option()\r\n  private menuOffsetTop: string;\r\n  @Input()\r\n  @Option()\r\n  private menuOffsetLeft: string;\r\n\r\n  // Re-declare field to declare ng @Output.\r\n  // --- from AbstractHasData\r\n  @Output('phxLoad')\r\n  @Option('load')\r\n  protected loadEvent: EventEmitter<any>;\r\n\r\n  // --- from Self\r\n\r\n  @I18N()\r\n  protected menuModel: MenuModel;\r\n  protected contextMenu: ContextMenu;\r\n  protected needFocusService: NeedFocusService;\r\n  protected autoFocus: boolean;\r\n\r\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService) {\r\n    super(elementRef);\r\n\r\n    this.needFocusService = needFocusService;\r\n    this.autoFocus = true;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.init();\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {\r\n      this.contextMenu.setContext(null);\r\n    }\r\n  }\r\n\r\n  public init(): void {\r\n    if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {\r\n      this.contextMenu.setContext(this);\r\n    }\r\n\r\n    if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') {\r\n      this.menuModel = this.menuFactory.createMenuModel(this);\r\n    }\r\n  }\r\n\r\n  public recreateMenuModel(): void {\r\n    this.menuModel = this.menuFactory.createMenuModel(this);\r\n  }\r\n\r\n  public onMoreButtonClick($event: Event) {\r\n    if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') {\r\n      if (this.contextMenu.isShow()) {\r\n        setTimeout(()=>{\r\n          this.hideMenu();\r\n        }, 50);\r\n      } else {\r\n        let anchorEl: any = this.elementRef.nativeElement;\r\n\r\n        if (this.anchorComponent !== null && this.anchorComponent !== undefined) {\r\n          anchorEl = this.anchorComponent.elementRef.nativeElement;\r\n        } else if (this.anchorSelector !== null && typeof this.anchorSelector === 'string') {\r\n          let selector: any = $(this.anchorSelector);\r\n\r\n          if (selector.length > 0) {\r\n            anchorEl = selector[0];\r\n          }\r\n        }\r\n\r\n        let offsetTop: number = 0;\r\n        let offsetLeft: number = 0;\r\n\r\n        if (this.menuOffsetTop !== null && typeof this.menuOffsetTop === 'number') {\r\n          offsetTop = this.menuOffsetTop;\r\n        }\r\n        if (this.menuOffsetLeft !== null && typeof this.menuOffsetLeft === 'number') {\r\n          offsetLeft = this.menuOffsetLeft;\r\n        }\r\n\r\n        let top = $(anchorEl).offset().top + $(anchorEl).height() + offsetTop;  \r\n        let leftEllipsisButton = $(this.elementRef.nativeElement).offset().left + offsetLeft;\r\n        let widthEllipsisButton = $(this.elementRef.nativeElement).outerWidth();\r\n        let setLeft = leftEllipsisButton + widthEllipsisButton;  \r\n        this.contextMenu.showAt(top, setLeft);\r\n      }\r\n    }\r\n  }\r\n\r\n  public getContextMenu(): ContextMenu {\r\n    return this.contextMenu;\r\n  }\r\n\r\n  public setContextMenu(menu: ContextMenu): void {\r\n    this.contextMenu = menu;\r\n  }\r\n\r\n  public getMenuModelFactory(): IMenuModelFactory {\r\n    return this.menuFactory;\r\n  }\r\n\r\n  public setMenuModelFactory(menuFactory: IMenuModelFactory): void {\r\n    this.menuFactory = menuFactory;\r\n  }\r\n\r\n  public getMenuModel(): MenuModel {\r\n    return this.menuModel;\r\n  }\r\n\r\n  public isSelfDataDirty(): boolean {\r\n    return false;\r\n  }\r\n\r\n  public selfSaveData(data: any): void {\r\n\r\n  }\r\n\r\n  public selfResetData(): void {\r\n\r\n  }\r\n\r\n  public doPreload(): Promise<any> {     return new Promise((resolve, reject) => {       resolve(null);     });   }  public doLoaded(): void {\r\n\r\n  }\r\n\r\n  public isIconURLEmpty(): boolean {\r\n    if (this.iconURL == null || this.iconURL === undefined) {\r\n      return true;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  public getIconURL(): string {\r\n    return this.iconURL;\r\n  }\r\n\r\n  public getStyleClasses(): string[] {\r\n    return this.styleClasses;\r\n  }\r\n\r\n  public hideMenu(): void {\r\n    if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {\r\n      this.contextMenu.hide();\r\n    }\r\n  }\r\n\r\n  public isShowMenu(): boolean {\r\n    return this.contextMenu.isShow();\r\n  }\r\n\r\n  public isAutoFocus(): boolean {\r\n    return this.autoFocus;\r\n  }\r\n\r\n  public onFocus(event: any): void {\r\n  }\r\n\r\n  public onLostFocus(event: any): void {\r\n    this.hideMenu();\r\n  }\r\n\r\n  public _doFocus($event: Event): void {\r\n    // do something when focus\r\n  }\r\n\r\n  public _doLostFocus($event: Event): void {\r\n    if (this.needFocusService !== null) {\r\n        this.needFocusService.resetFocusingComponent(this);\r\n    }\r\n  }\r\n}\r\n"]}