com.phloxui
Version:
PhloxUI Ng2+ Framework
467 lines (466 loc) • 35.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, Input, Output, EventEmitter, ElementRef } from '@angular/core';
import { ActionModel, ActionModelMenu } from '../../model/models';
import { ContextMenu } from '../../ContextMenu.component';
import { DefaultActionModelMenuFactory } from '../DefaultActionModelMenuFactory';
import { Option } from '../../../decorator/Option.decorator';
import { I18N } from '../../../decorator/I18N.decorator';
import { AbstractI18NApplicable } from '../../../share/AbstractI18NApplicable';
import { NeedFocusService } from '../../../service/NeedFocusService.service';
var /** @type {?} */ TYPE_NAME = "phx-action-btn";
var ActionButton = /** @class */ (function (_super) {
tslib_1.__extends(ActionButton, _super);
function ActionButton(elementRef, needFocusService) {
var _this = _super.call(this) || this;
_this.ACTION_CONTEXT_MENU_TOP_REDUCE = 5;
_this.clickEvent = new EventEmitter();
_this.beforeClickEvent = new EventEmitter();
_this.elementRef = elementRef;
_this.needFocusService = needFocusService;
return _this;
}
/**
* @return {?}
*/
ActionButton.prototype.ngOnInit = /**
* @return {?}
*/
function () {
if (!this.model && this.options && this.options['model']) {
this.model = new ActionModel();
this.model.setOptions(this.options['model']);
}
this.init();
};
/**
* @return {?}
*/
ActionButton.prototype._getStyleClasses = /**
* @return {?}
*/
function () {
if (this.model !== null && this.model !== undefined) {
if (this.model.styleClasses !== null && this.model.styleClasses !== undefined) {
return this.model.styleClasses;
}
}
return [];
};
/**
* @return {?}
*/
ActionButton.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);
}
else {
this.menuFactory = new DefaultActionModelMenuFactory();
this.menuModel = this.menuFactory.createMenuModel(this);
}
};
/**
* @param {?} $event
* @return {?}
*/
ActionButton.prototype.doFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
$(this.elementRef.nativeElement).find("div > button").focus();
};
/**
* @param {?} $event
* @return {?}
*/
ActionButton.prototype.doBlur = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
$(this.elementRef.nativeElement).find("div > button").blur();
};
/**
* @param {?} $event
* @return {?}
*/
ActionButton.prototype.onActionBtnClicked = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (this.model === null || typeof this.model === 'undefined') {
return;
}
this.doFocus($event);
if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') {
this.contextMenu.hide();
}
if (this.model.actionPerformedHandler !== null && typeof this.model.actionPerformedHandler !== 'undefined') {
this.model.actionPerformedHandler.call(null, $event);
}
else {
this.onMoreBtnClicked($event);
}
this.beforeClickEvent.emit($event);
this.clickEvent.emit($event);
};
/**
* @param {?} $event
* @return {?}
*/
ActionButton.prototype.onMoreBtnClicked = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (this.model === null || typeof this.model === 'undefined') {
return;
}
this.doFocus($event);
if (this.model.constructor.name === 'ActionModelMenu') {
$event.stopPropagation();
if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') {
this.menuModel = this.menuFactory.createMenuModel(this);
}
if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') {
if (this.contextMenu.isShow()) {
this.contextMenu.hide();
}
else {
var /** @type {?} */ top_1 = $(this.elementRef.nativeElement).offset().top + $(this.elementRef.nativeElement).height();
var /** @type {?} */ leftActionButton = $(this.elementRef.nativeElement).offset().left;
var /** @type {?} */ widthActionButton = $(this.elementRef.nativeElement).outerWidth();
var /** @type {?} */ setLeft = leftActionButton + widthActionButton;
top_1 = top_1 - this.ACTION_CONTEXT_MENU_TOP_REDUCE;
this.contextMenu.showAt(top_1, setLeft);
}
}
}
};
/**
* @return {?}
*/
ActionButton.prototype._isShowMoreBtn = /**
* @return {?}
*/
function () {
if (this.model === null || typeof this.model === 'undefined') {
return false;
}
if (this.model instanceof ActionModelMenu) {
return true;
}
return false;
};
/**
* @return {?}
*/
ActionButton.prototype._hasIcon = /**
* @return {?}
*/
function () {
if (this.model !== null && this.model != undefined) {
if (this.model.iconURL !== null && this.model.iconURL != undefined) {
return true;
}
}
return false;
};
/**
* @return {?}
*/
ActionButton.prototype.getClickEvent = /**
* @return {?}
*/
function () {
return this.clickEvent;
};
/**
* @param {?} event
* @return {?}
*/
ActionButton.prototype.setClickedEvent = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.clickEvent = event;
};
/**
* @return {?}
*/
ActionButton.prototype.getBeforeClickEvent = /**
* @return {?}
*/
function () {
return this.beforeClickEvent;
};
/**
* @param {?} event
* @return {?}
*/
ActionButton.prototype.setBeforeClickedEvent = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.beforeClickEvent = event;
};
/**
* @param {?} context
* @return {?}
*/
ActionButton.prototype.isShow = /**
* @param {?} context
* @return {?}
*/
function (context) {
if (this.model.isShow === null) {
return false;
}
if (typeof this.model.isShow !== 'function') {
return false;
}
return this.model.isShow(context);
};
/**
* @param {?} context
* @return {?}
*/
ActionButton.prototype.isEnabled = /**
* @param {?} context
* @return {?}
*/
function (context) {
if (this.model.isEnabled === null) {
return false;
}
if (typeof this.model.isEnabled !== 'function') {
return false;
}
return this.model.isEnabled(context);
};
/**
* @return {?}
*/
ActionButton.prototype.getContextMenu = /**
* @return {?}
*/
function () {
return this.contextMenu;
};
/**
* @param {?} menu
* @return {?}
*/
ActionButton.prototype.setContextMenu = /**
* @param {?} menu
* @return {?}
*/
function (menu) {
this.contextMenu = menu;
if (this.contextMenu) {
if (this.options && this.options['menu']) {
this.contextMenu.setOptions(this.options['menu']);
}
if (this.i18nValue && this.i18nValue['menu']) {
this.contextMenu.applyI18N(this.i18nValue['menu']);
}
}
};
/**
* @return {?}
*/
ActionButton.prototype.getMenuModelFactory = /**
* @return {?}
*/
function () {
return this.menuFactory;
};
/**
* @param {?} menuFactory
* @return {?}
*/
ActionButton.prototype.setMenuModelFactory = /**
* @param {?} menuFactory
* @return {?}
*/
function (menuFactory) {
this.menuFactory = menuFactory;
};
/**
* @return {?}
*/
ActionButton.prototype.hasModel = /**
* @return {?}
*/
function () {
if (this.model !== null && this.model != undefined) {
return true;
}
return false;
};
/**
* @return {?}
*/
ActionButton.prototype.getModel = /**
* @return {?}
*/
function () {
return this.model;
};
/**
* @param {?} model
* @return {?}
*/
ActionButton.prototype.setModel = /**
* @param {?} model
* @return {?}
*/
function (model) {
this.model = model;
if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') {
this.menuModel = this.menuFactory.createMenuModel(this);
}
};
/**
* @return {?}
*/
ActionButton.prototype.getMenuModel = /**
* @return {?}
*/
function () {
return this.menuModel;
};
/**
* @param {?} event
* @return {?}
*/
ActionButton.prototype.onLostFocusing = /**
* @param {?} event
* @return {?}
*/
function (event) {
};
/**
* @param {?} event
* @return {?}
*/
ActionButton.prototype.focusing = /**
* @param {?} event
* @return {?}
*/
function (event) {
};
/**
* @param {?} event
* @return {?}
*/
ActionButton.prototype.onLostFocus = /**
* @param {?} event
* @return {?}
*/
function (event) {
};
/**
* @param {?} event
* @return {?}
*/
ActionButton.prototype.onFocus = /**
* @param {?} event
* @return {?}
*/
function (event) {
};
ActionButton.TYPE_NAME = TYPE_NAME;
ActionButton.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"phx-action-button\" *ngIf=\"hasModel()\" [ngClass]=\"_getStyleClasses()\">\n\t<div class=\"group\" [class.more]=\"_isShowMoreBtn()\" *ngIf=\"!_isShowMoreBtn()\">\n\t\t<button (click)=\"onActionBtnClicked($event)\">\n\t\t\t<img *ngIf=\"_hasIcon()\" src=\"{{getModel().iconURL}}\" title=\"{{getModel().label}}\">\n\t\t\t{{getModel().label}}\n\t\t</button>\n\t</div>\n\t<div class=\"more-menu\" *ngIf=\"_isShowMoreBtn()\">\n\t\t<button (click)=\"onMoreBtnClicked($event)\">\n\t\t\t<div class=\"wrapper\">\n\t\t\t\t<div>\n\t\t\t\t\t{{getModel().label}}\n\t\t\t\t</div>\n\t\t\t\t<div>\n\t\t\t\t\t<div class=\"icon-arrow-down\"></div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</button>\n\t</div>\n</div>\n<phx-context-menu *ngIf=\"getMenuModel() !== null\" [model]=\"getMenuModel()\" [context]=\"this\" class=\"vertical\"></phx-context-menu>\n"
},] },
];
/** @nocollapse */
ActionButton.ctorParameters = function () { return [
{ type: ElementRef, },
{ type: NeedFocusService, },
]; };
ActionButton.propDecorators = {
"menuFactory": [{ type: Input },],
"model": [{ type: Input },],
"options": [{ type: Input },],
"beforeClickEvent": [{ type: Output, args: ['phxBeforeClick',] },],
"clickEvent": [{ type: Output, args: ['phxClick',] },],
};
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], ActionButton.prototype, "menuFactory", void 0);
tslib_1.__decorate([
I18N(),
Option(),
tslib_1.__metadata("design:type", ActionModel)
], ActionButton.prototype, "model", void 0);
tslib_1.__decorate([
Option('beforeClick'),
tslib_1.__metadata("design:type", EventEmitter)
], ActionButton.prototype, "beforeClickEvent", void 0);
tslib_1.__decorate([
Option('click'),
tslib_1.__metadata("design:type", EventEmitter)
], ActionButton.prototype, "clickEvent", void 0);
tslib_1.__decorate([
I18N('menu'),
Option('menu'),
tslib_1.__metadata("design:type", ContextMenu)
], ActionButton.prototype, "contextMenu", void 0);
return ActionButton;
}(AbstractI18NApplicable));
export { ActionButton };
function ActionButton_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
ActionButton.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
ActionButton.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
ActionButton.propDecorators;
/** @type {?} */
ActionButton.TYPE_NAME;
/** @type {?} */
ActionButton.prototype.ACTION_CONTEXT_MENU_TOP_REDUCE;
/** @type {?} */
ActionButton.prototype.menuFactory;
/** @type {?} */
ActionButton.prototype.model;
/** @type {?} */
ActionButton.prototype.options;
/** @type {?} */
ActionButton.prototype.beforeClickEvent;
/** @type {?} */
ActionButton.prototype.clickEvent;
/** @type {?} */
ActionButton.prototype.contextMenu;
/** @type {?} */
ActionButton.prototype.menuModel;
/** @type {?} */
ActionButton.prototype.elementRef;
/** @type {?} */
ActionButton.prototype.needFocusService;
/** @type {?} */
ActionButton.prototype._itemLostFocusingTimeout;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ActionButton.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/editor/editor.internal/ActionButton.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, ElementRef } from '@angular/core';\nimport { ActionModel, ActionModelMenu, MenuModel } from '../../model/models';\nimport { IContext } from '../../IContext';\nimport { IHasModel } from '../../IHasModel';\nimport { INeedFocus } from '../../INeedFocus';\nimport { ContextMenu } from '../../ContextMenu.component';\nimport { IMenuModelFactory } from '../../IMenuModelFactory';\nimport { DefaultActionModelMenuFactory } from '../DefaultActionModelMenuFactory';\nimport { Option } from '../../../decorator/Option.decorator';\nimport { I18N } from '../../../decorator/I18N.decorator';\nimport { AbstractI18NApplicable } from '../../../share/AbstractI18NApplicable';\nimport { NeedFocusService } from '../../../service/NeedFocusService.service';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-action-btn\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-action-button\" *ngIf=\"hasModel()\" [ngClass]=\"_getStyleClasses()\">\n\t<div class=\"group\" [class.more]=\"_isShowMoreBtn()\" *ngIf=\"!_isShowMoreBtn()\">\n\t\t<button (click)=\"onActionBtnClicked($event)\">\n\t\t\t<img *ngIf=\"_hasIcon()\" src=\"{{getModel().iconURL}}\" title=\"{{getModel().label}}\">\n\t\t\t{{getModel().label}}\n\t\t</button>\n\t</div>\n\t<div class=\"more-menu\" *ngIf=\"_isShowMoreBtn()\">\n\t\t<button (click)=\"onMoreBtnClicked($event)\">\n\t\t\t<div class=\"wrapper\">\n\t\t\t\t<div>\n\t\t\t\t\t{{getModel().label}}\n\t\t\t\t</div>\n\t\t\t\t<div>\n\t\t\t\t\t<div class=\"icon-arrow-down\"></div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</button>\n\t</div>\n</div>\n<phx-context-menu *ngIf=\"getMenuModel() !== null\" [model]=\"getMenuModel()\" [context]=\"this\" class=\"vertical\"></phx-context-menu>\n`\n})\nexport class ActionButton extends AbstractI18NApplicable implements OnInit, IContext, IHasModel, INeedFocus {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  private ACTION_CONTEXT_MENU_TOP_REDUCE: number = 5; // as pixel\n  @Input()\n  @Option()\n  private menuFactory: IMenuModelFactory;\n  @Input()\n  @I18N()\n  @Option()\n  private model: ActionModel;\n  @Input()\n  protected options: any;\n  @Option('beforeClick')\n  @Output('phxBeforeClick')\n  private beforeClickEvent: EventEmitter<any>;\n  @Option('click')\n  @Output('phxClick')\n  private clickEvent: EventEmitter<any>;\n  // contextMenu & menuModel is dynamically created.\n  // ! TODO Why \"contextMenu\" is not bound ty @ViewChild?\n  @I18N('menu')\n  @Option('menu')\n  private contextMenu: ContextMenu;\n  private menuModel: MenuModel;\n\n  private elementRef: ElementRef;\n  private needFocusService: NeedFocusService;\n  private _itemLostFocusingTimeout: any;\n\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService) {\n    super();\n    this.clickEvent = new EventEmitter();\n    this.beforeClickEvent = new EventEmitter();\n    this.elementRef = elementRef;\n    this.needFocusService = needFocusService;\n  }\n\n  public ngOnInit(): void {\n    if (!this.model && this.options && this.options['model']) {\n      this.model = new ActionModel();\n\n      this.model.setOptions(this.options['model']);\n    }\n\n    this.init();\n  }\n\n  public _getStyleClasses(): string[] {\n    if(this.model !== null && this.model !== undefined){\n      if(this.model.styleClasses !== null && this.model.styleClasses !== undefined){\n        return this.model.styleClasses;\n      }\n    }\n\n    return [];\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    } else {\n      this.menuFactory = new DefaultActionModelMenuFactory();\n      this.menuModel = this.menuFactory.createMenuModel(this);\n    }\n  }\n\n  protected doFocus($event: Event): void {\n    $(this.elementRef.nativeElement).find(\"div > button\").focus();\n  }\n\n  protected doBlur($event: Event): void {\n    $(this.elementRef.nativeElement).find(\"div > button\").blur();\n  }\n\n  public onActionBtnClicked($event: Event): void {\n    if (this.model === null || typeof this.model === 'undefined') {\n      return;\n    }\n\n    this.doFocus($event);\n\n    if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') {\n      this.contextMenu.hide();\n    }\n    if (this.model.actionPerformedHandler !== null && typeof this.model.actionPerformedHandler !== 'undefined') {\n      this.model.actionPerformedHandler.call(null, $event);\n    } else {\n      this.onMoreBtnClicked($event);\n    }\n\n    this.beforeClickEvent.emit($event);\n    this.clickEvent.emit($event);\n  }\n\n  public onMoreBtnClicked($event: Event): void {\n    if (this.model === null || typeof this.model === 'undefined') {\n      return;\n    }\n\n    this.doFocus($event);\n\n    if (this.model.constructor.name === 'ActionModelMenu') {\n      $event.stopPropagation();\n\n      if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') {\n        this.menuModel = this.menuFactory.createMenuModel(this);\n      }\n\n      if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') {\n        if (this.contextMenu.isShow()) {\n          this.contextMenu.hide();\n        } else { \n          let top = $(this.elementRef.nativeElement).offset().top + $(this.elementRef.nativeElement).height();\n          let leftActionButton = $(this.elementRef.nativeElement).offset().left;\n          let widthActionButton = $(this.elementRef.nativeElement).outerWidth();\n          let setLeft = leftActionButton + widthActionButton;   \n          top = top - this.ACTION_CONTEXT_MENU_TOP_REDUCE;\n\n          this.contextMenu.showAt(top, setLeft); \n        }\n      }\n    }\n  }\n\n  public _isShowMoreBtn(): boolean {\n    if (this.model === null || typeof this.model === 'undefined') {\n      return false;\n    }\n\n    if (this.model instanceof ActionModelMenu) {\n      return true;\n    }\n\n    return false;\n  }\n\n  public _hasIcon(): boolean {\n    if (this.model !== null && this.model != undefined) {\n      if (this.model.iconURL !== null && this.model.iconURL != undefined) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  public getClickEvent(): EventEmitter<any> {\n    return this.clickEvent;\n  }\n\n  public setClickedEvent(event: EventEmitter<any>): void {\n    this.clickEvent = event;\n  }\n\n  public getBeforeClickEvent(): EventEmitter<any> {\n    return this.beforeClickEvent;\n  }\n\n  public setBeforeClickedEvent(event: EventEmitter<any>): void {\n    this.beforeClickEvent = event;\n  }\n\n  public isShow(context: IContext): boolean {\n    if (this.model.isShow === null) {\n      return false;\n    }\n    if (typeof this.model.isShow !== 'function') {\n      return false\n    }\n    return this.model.isShow(context);\n  }\n\n  public isEnabled(context: IContext): boolean {\n    if (this.model.isEnabled === null) {\n      return false;\n    }\n    if (typeof this.model.isEnabled !== 'function') {\n      return false\n    }\n    return this.model.isEnabled(context);\n  }\n\n  public getContextMenu(): ContextMenu {\n    return this.contextMenu;\n  }\n\n  public setContextMenu(menu: ContextMenu): void {\n    this.contextMenu = menu;\n\n    if (this.contextMenu) {\n      if (this.options && this.options['menu']) {\n        this.contextMenu.setOptions(this.options['menu']);\n      }\n      if (this.i18nValue && this.i18nValue['menu']) {\n        this.contextMenu.applyI18N(this.i18nValue['menu']);\n      }\n    }\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 hasModel(): boolean {\n    if (this.model !== null && this.model != undefined) {\n      return true;\n    }\n\n    return false;\n  }\n\n  public getModel(): any {\n    return this.model;\n  }\n\n  public setModel(model: any): void {\n    this.model = model;\n    if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') {\n      this.menuModel = this.menuFactory.createMenuModel(this);\n    }\n  }\n\n  public getMenuModel(): MenuModel {\n    return this.menuModel;\n  }\n  \n  public onLostFocusing(event: any): void {\n    \n  }\n\n  public focusing(event: any): void {\n\n  }\n\n  public onLostFocus(event: any): void {\n    \n  }\n\n  public onFocus(event: any): void {\n\n  }\n}\n"]}