com.phloxui
Version:
PhloxUI Ng2+ Framework
440 lines (439 loc) • 30.4 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 { TabModel } from '../../model/TabModel';
import { AbstractHasDataHelp } from '../../AbstractHasDataHelp';
import { AbstractDataView } from '../../dataview/AbstractDataView';
import { Option } from '../../../decorator/Option.decorator';
import { I18N } from '../../../decorator/I18N.decorator';
import { NeedFocusService } from '../../../service/NeedFocusService.service';
var /** @type {?} */ TYPE_NAME = "phx-tab";
var Tab = /** @class */ (function (_super) {
tslib_1.__extends(Tab, _super);
function Tab(elementRef, needFocusService) {
var _this = _super.call(this, elementRef) || this;
_this.showMoreMenu = false;
_this.needFocusService = needFocusService;
return _this;
}
/**
* @return {?}
*/
Tab.prototype.ngOnInit = /**
* @return {?}
*/
function () {
if (this.tabPane !== null && typeof this.tabPane !== 'undefined') {
this.tabPane.addTabHeader(this);
}
if (this.model !== null && typeof this.model !== 'undefined') {
if (this.model.data !== null && typeof this.model.data !== 'undefined') {
this.data = this.model.data;
}
}
};
/**
* @return {?}
*/
Tab.prototype.getTabLabel = /**
* @return {?}
*/
function () {
if (this.model !== null && typeof this.model !== 'undefined') {
var /** @type {?} */ defaultLabel = (this.model.label === null || typeof this.model.label === 'undefined') ? '' : this.model.label;
var /** @type {?} */ resolveLabel = null;
if (this.model.labelField !== null && typeof this.model.labelField !== 'undefined' && this.model.labelField !== '') {
resolveLabel = AbstractDataView.resolveMappedData(this.model.labelField, this.data);
}
if (resolveLabel !== null && typeof resolveLabel === 'string' && resolveLabel !== '') {
return resolveLabel;
}
else {
return defaultLabel;
}
}
return '';
};
/**
* @return {?}
*/
Tab.prototype.init = /**
* @return {?}
*/
function () {
if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {
this.contextMenu.setContext(this);
}
};
/**
* @param {?} $event
* @return {?}
*/
Tab.prototype.onMoreButtonClick = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
$event.stopPropagation();
if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') {
if (this.contextMenu.isShow()) {
if (this.needFocusService !== null && this.needFocusService !== undefined) {
this.needFocusService.resetFocusingComponent(this);
}
}
else {
var /** @type {?} */ top_1 = $(this.elementRef.nativeElement).offset().top + $(this.elementRef.nativeElement).height();
var /** @type {?} */ left = $(this.elementRef.nativeElement).offset().left - 1;
var /** @type {?} */ width = $(this.elementRef.nativeElement).width() + 2;
this.contextMenu.showAt(top_1, left, width);
if (this.needFocusService !== null && this.needFocusService !== undefined) {
this.needFocusService.setFocusingComponent(this);
}
}
}
};
/**
* @return {?}
*/
Tab.prototype.hideMenu = /**
* @return {?}
*/
function () {
if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {
this.contextMenu.hide();
}
};
/**
* @return {?}
*/
Tab.prototype.getIndex = /**
* @return {?}
*/
function () {
if (this.tabPane !== null && typeof this.tabPane !== 'undefined') {
return this.tabPane.getTabModelIndex(this.model);
}
return -1;
};
/**
* @param {?} selected
* @return {?}
*/
Tab.prototype.setSelected = /**
* @param {?} selected
* @return {?}
*/
function (selected) {
this.selected = selected;
};
/**
* @return {?}
*/
Tab.prototype.getContextMenu = /**
* @return {?}
*/
function () {
return this.contextMenu;
};
/**
* @param {?} menu
* @return {?}
*/
Tab.prototype.setContextMenu = /**
* @param {?} menu
* @return {?}
*/
function (menu) {
this.contextMenu = menu;
};
/**
* @return {?}
*/
Tab.prototype.getMenuModelFactory = /**
* @return {?}
*/
function () {
return this.menuFactory;
};
/**
* @param {?} menuFactory
* @return {?}
*/
Tab.prototype.setMenuModelFactory = /**
* @param {?} menuFactory
* @return {?}
*/
function (menuFactory) {
this.menuFactory = menuFactory;
};
/**
* @return {?}
*/
Tab.prototype.getModel = /**
* @return {?}
*/
function () {
return this.model;
};
/**
* @return {?}
*/
Tab.prototype.isSelfDataDirty = /**
* @return {?}
*/
function () {
return false;
};
/**
* @param {?} data
* @return {?}
*/
Tab.prototype.selfSaveData = /**
* @param {?} data
* @return {?}
*/
function (data) {
};
/**
* @return {?}
*/
Tab.prototype.selfResetData = /**
* @return {?}
*/
function () {
};
/**
* @return {?}
*/
Tab.prototype.getTabBody = /**
* @return {?}
*/
function () {
if (this.tabPane !== null && typeof this.tabPane !== 'undefined') {
var /** @type {?} */ index = this.tabPane.getTabHeaderIndex(this);
return this.tabPane.getTabBody(index);
}
return null;
};
/**
* @return {?}
*/
Tab.prototype.isShowMoreMenu = /**
* @return {?}
*/
function () {
return this.showMoreMenu;
};
/**
* @return {?}
*/
Tab.prototype.doPreload = /**
* @return {?}
*/
function () {
return Promise.resolve(null);
};
/**
* @return {?}
*/
Tab.prototype.doLoaded = /**
* @return {?}
*/
function () {
};
/**
* @param {?} $event
* @return {?}
*/
Tab.prototype._doFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
// do something when focus
};
/**
* @param {?} $event
* @return {?}
*/
Tab.prototype._doLostFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
if (this.needFocusService !== null) {
this.needFocusService.resetFocusingComponent(this);
}
};
/**
* @param {?} event
* @return {?}
*/
Tab.prototype.onFocus = /**
* @param {?} event
* @return {?}
*/
function (event) {
$(this.elementRef.nativeElement).find(".fake").focus();
};
/**
* @param {?} event
* @return {?}
*/
Tab.prototype.onLostFocus = /**
* @param {?} event
* @return {?}
*/
function (event) {
var _this = this;
if (this.lostFocusTimeout !== null && this.lostFocusTimeout !== undefined) {
clearTimeout(this.lostFocusTimeout);
}
this.lostFocusTimeout = setTimeout(function () {
_this.hideMenu();
$(_this.elementRef.nativeElement).find(".fake").blur();
}, 320);
};
Tab.TYPE_NAME = TYPE_NAME;
Tab.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"table-wrapper\">\n\t<div class=\"table-cell-wrapper middle\">\n\t\t<div *ngIf=\"getModel() != null\" class=\"phx-tab\" [class.dirty]=\"isDataDirty()\" [ngClass]=\"getModel().styleClass\">\n\t\t\t<div class=\"tab-name\">{{getTabLabel()}}</div> <div *ngIf=\"isShowMoreMenu()\" class=\"tab-vertical-ellipsis\" (click)=\"onMoreButtonClick($event)\"></div>\n\t\t\t<phx-context-menu [model]=\"getModel().menuModel\" [dataParent]=\"this\" [context]=\"this\" class=\"vertical\" [autoFocus]=\"false\"></phx-context-menu>\n\t\t</div>\n\t</div>\n\t<button type=\"button\" class=\"fake\" (focusin)=\"_doFocus($event)\" (blur)=\"_doLostFocus($event)\"></button>\n</div>\n"
},] },
];
/** @nocollapse */
Tab.ctorParameters = function () { return [
{ type: ElementRef, },
{ type: NeedFocusService, },
]; };
Tab.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 },],
"help": [{ type: Input },],
"model": [{ type: Input },],
"tabPane": [{ type: Input },],
"menuFactory": [{ type: Input },],
"showMoreMenu": [{ type: Input },],
};
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], Tab.prototype, "dataParent", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], Tab.prototype, "ignoreParentData", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], Tab.prototype, "data", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], Tab.prototype, "ignoreParentDisabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], Tab.prototype, "delegateHistory", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], Tab.prototype, "onDisabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], Tab.prototype, "onEnabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], Tab.prototype, "loadingEnabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], Tab.prototype, "i18nKey", void 0);
tslib_1.__decorate([
Option('i18nBypass'),
tslib_1.__metadata("design:type", Boolean)
], Tab.prototype, "bypass", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], Tab.prototype, "disabled", void 0);
tslib_1.__decorate([
I18N(),
Option(),
tslib_1.__metadata("design:type", Object)
], Tab.prototype, "help", void 0);
return Tab;
}(AbstractHasDataHelp));
export { Tab };
function Tab_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
Tab.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
Tab.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
Tab.propDecorators;
/** @type {?} */
Tab.TYPE_NAME;
/** @type {?} */
Tab.prototype.dataParent;
/** @type {?} */
Tab.prototype.ignoreParentData;
/** @type {?} */
Tab.prototype.data;
/** @type {?} */
Tab.prototype.ignoreParentDisabled;
/** @type {?} */
Tab.prototype.delegateHistory;
/** @type {?} */
Tab.prototype.onDisabled;
/** @type {?} */
Tab.prototype.onEnabled;
/** @type {?} */
Tab.prototype.loadingEnabled;
/** @type {?} */
Tab.prototype.i18nKey;
/** @type {?} */
Tab.prototype.bypass;
/** @type {?} */
Tab.prototype.options;
/** @type {?} */
Tab.prototype.disabled;
/** @type {?} */
Tab.prototype.help;
/** @type {?} */
Tab.prototype.model;
/** @type {?} */
Tab.prototype.tabPane;
/** @type {?} */
Tab.prototype.contextMenu;
/** @type {?} */
Tab.prototype.menuFactory;
/** @type {?} */
Tab.prototype.selected;
/** @type {?} */
Tab.prototype.showMoreMenu;
/** @type {?} */
Tab.prototype.lostFocusTimeout;
/** @type {?} */
Tab.prototype.needFocusService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Tab.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/dataview/tab.internal/Tab.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, ViewChild } from '@angular/core';\nimport { TabModel } from '../../model/TabModel';\nimport { ContextMenu } from '../../ContextMenu.component';\nimport { IContext } from '../../IContext';\nimport { IHasData } from '../../IHasData';\nimport { INeedFocus } from '../../INeedFocus';\nimport { IMenuModelFactory } from '../../IMenuModelFactory';\nimport { AbstractHasDataHelp } from '../../AbstractHasDataHelp';\nimport { AbstractDataView } from '../../dataview/AbstractDataView';\nimport { Option } from '../../../decorator/Option.decorator';\nimport { I18N } from '../../../decorator/I18N.decorator';\nimport { NeedFocusService } from '../../../service/NeedFocusService.service';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-tab\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"table-wrapper\">\n\t<div class=\"table-cell-wrapper middle\">\n\t\t<div *ngIf=\"getModel() != null\" class=\"phx-tab\" [class.dirty]=\"isDataDirty()\" [ngClass]=\"getModel().styleClass\">\n\t\t\t<div class=\"tab-name\">{{getTabLabel()}}</div> <div *ngIf=\"isShowMoreMenu()\" class=\"tab-vertical-ellipsis\" (click)=\"onMoreButtonClick($event)\"></div>\n\t\t\t<phx-context-menu [model]=\"getModel().menuModel\" [dataParent]=\"this\" [context]=\"this\" class=\"vertical\" [autoFocus]=\"false\"></phx-context-menu>\n\t\t</div>\n\t</div>\n\t<button type=\"button\" class=\"fake\" (focusin)=\"_doFocus($event)\" (blur)=\"_doLostFocus($event)\"></button>\n</div>\n`\n})\nexport class Tab extends AbstractHasDataHelp implements OnInit, IContext, INeedFocus {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  // Re-declare field to declare ng @Input.\n  // --- from AbstractHasData\n  @Input()\n  @Option()\n  protected dataParent: IHasData;\n  @Input()\n  @Option()\n  protected ignoreParentData: boolean;\n  @Input()\n  @Option()\n  protected data: any;\n  @Input()\n  @Option()\n  protected ignoreParentDisabled: boolean;\n  @Input()\n  @Option()\n  protected delegateHistory: boolean;\n  @Input()\n  @Option()\n  protected onDisabled: Function;\n  @Input()\n  @Option()\n  protected onEnabled: Function;\n  @Input()\n  @Option()\n  protected loadingEnabled: boolean;\n  @Input()\n  @Option()\n  protected i18nKey: string;\n  @Input('i18nBypass')\n  @Option('i18nBypass')\n  protected bypass: boolean;\n  @Input()\n  protected options: any;\n  @Input()\n  @Option()\n  protected disabled: boolean;\n  // --- from AbstractHasDataHelp\n  @Input()\n  @I18N()\n  @Option()\n  protected help: any;\n\n  // --- from self\n  @Input()\n  private model: TabModel;\n  @Input()\n  private tabPane: any;\n  private contextMenu: ContextMenu;\n  @Input()\n  private menuFactory: IMenuModelFactory;\n  private selected: boolean;\n  @Input()\n  private showMoreMenu: boolean;\n  private lostFocusTimeout: any;\n  protected needFocusService: NeedFocusService;\n\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService) {\n    super(elementRef);\n    this.showMoreMenu = false;\n    this.needFocusService = needFocusService;\n  }\n\n  public ngOnInit(): void {\n    if (this.tabPane !== null && typeof this.tabPane !== 'undefined') {\n      this.tabPane.addTabHeader(this);\n    }\n    if (this.model !== null && typeof this.model !== 'undefined') {\n      if (this.model.data !== null && typeof this.model.data !== 'undefined') {\n        this.data = this.model.data;\n      }\n    }\n  }\n\n  public getTabLabel(): string {\n    if (this.model !== null && typeof this.model !== 'undefined') {\n      let defaultLabel = (this.model.label === null || typeof this.model.label === 'undefined') ? '' : this.model.label;\n      let resolveLabel = null;\n      if (this.model.labelField !== null && typeof this.model.labelField !== 'undefined' && this.model.labelField !== '') {\n        resolveLabel = AbstractDataView.resolveMappedData(this.model.labelField, this.data);\n      }\n\n      if (resolveLabel !== null && typeof resolveLabel === 'string' && resolveLabel !== '') {\n        return resolveLabel;\n      } else {\n        return defaultLabel;\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  }\n\n  public onMoreButtonClick($event: Event) {\n    $event.stopPropagation();\n\n    if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') {\n      if (this.contextMenu.isShow()) {\n        if (this.needFocusService !== null && this.needFocusService !== undefined) {\n          this.needFocusService.resetFocusingComponent(this);\n        }\n      } else {\n        let top = $(this.elementRef.nativeElement).offset().top + $(this.elementRef.nativeElement).height();\n        let left = $(this.elementRef.nativeElement).offset().left - 1;\n        let width = $(this.elementRef.nativeElement).width() + 2;\n\n        this.contextMenu.showAt(top, left, width);\n\n        if (this.needFocusService !== null && this.needFocusService !== undefined) {\n          this.needFocusService.setFocusingComponent(this);\n        }\n      }\n    }\n  }\n\n  public hideMenu(): void {\n    if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {\n      this.contextMenu.hide();\n    }\n  }\n\n  public getIndex(): number {\n    if (this.tabPane !== null && typeof this.tabPane !== 'undefined') {\n      return this.tabPane.getTabModelIndex(this.model);\n    }\n    return -1;\n  }\n\n  public setSelected(selected: boolean): void {\n    this.selected = selected;\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 getModel(): TabModel {\n    return this.model;\n  }\n\n  public isSelfDataDirty(): boolean {\n    return false;\n  }\n\n  public selfSaveData(data: any): void {\n\n  }\n\n  public selfResetData(): void {\n\n  }\n\n  public getTabBody(): any {\n    if (this.tabPane !== null && typeof this.tabPane !== 'undefined') {\n      let index = this.tabPane.getTabHeaderIndex(this);\n      return this.tabPane.getTabBody(index);\n    }\n    return null;\n  }\n\n  public isShowMoreMenu(): boolean {\n    return this.showMoreMenu;\n  }\n\n  public doPreload(): Promise<any> {\n    return Promise.resolve(null);\n  }\n\n  public doLoaded(): void {\n\n  }\n\n  public _doFocus($event: Event): void {\n    // do something when focus\n  }\n\n  public _doLostFocus($event: Event): void {\n    if (this.needFocusService !== null) {\n      this.needFocusService.resetFocusingComponent(this);\n    }\n  }\n\n  public onFocus(event: any): void {\n    $(this.elementRef.nativeElement).find(\".fake\").focus()\n  }\n\n  public onLostFocus(event: any): void {\n    if(this.lostFocusTimeout !== null && this.lostFocusTimeout !== undefined){\n      clearTimeout(this.lostFocusTimeout);\n    }\n\n    this.lostFocusTimeout = setTimeout(()=>{\n      this.hideMenu();\n\n      $(this.elementRef.nativeElement).find(\".fake\").blur();\n    }, 320);\n  }\n}\n"]}