UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

354 lines (353 loc) 26.7 kB
/** * @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 { AbstractHasData } from './AbstractHasData'; import { AbstractDataView } from './dataview/AbstractDataView'; import { Option } from '../decorator/Option.decorator'; import { NeedFocusService } from '../service/NeedFocusService.service'; const /** @type {?} */ TYPE_NAME = "phx-tab"; export class Tab extends AbstractHasData { /** * @param {?} elementRef * @param {?} needFocusService */ constructor(elementRef, needFocusService) { super(elementRef); this.showMoreMenu = false; this._autoFocus = false; this.needFocusService = needFocusService; } /** * @return {?} */ ngOnInit() { 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 {?} */ getTabLabel() { if (this.model !== null && typeof this.model !== 'undefined') { let /** @type {?} */ defaultLabel = (this.model.label === null || typeof this.model.label === 'undefined') ? '' : this.model.label; let /** @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 {?} */ init() { if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') { this.contextMenu.setContext(this); } } /** * @param {?} $event * @return {?} */ onMoreButtonClick($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 { let /** @type {?} */ top = $(this.elementRef.nativeElement).offset().top + $(this.elementRef.nativeElement).height(); let /** @type {?} */ left = $(this.elementRef.nativeElement).offset().left - 1; let /** @type {?} */ width = $(this.elementRef.nativeElement).width() + 2; this.contextMenu.showAt(top, left, width); if (this.needFocusService !== null && this.needFocusService !== undefined) { this.needFocusService.setFocusingComponent(this); } } } } /** * @return {?} */ hideMenu() { if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') { this.contextMenu.hide(); } } /** * @return {?} */ getIndex() { if (this.tabPane !== null && typeof this.tabPane !== 'undefined') { return this.tabPane.getTabModelIndex(this.model); } return -1; } /** * @param {?} selected * @return {?} */ setSelected(selected) { this.selected = selected; } /** * @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 {?} */ getModel() { return this.model; } /** * @return {?} */ isSelfDataDirty() { return false; } /** * @return {?} */ selfSaveData() { } /** * @return {?} */ selfResetData() { } /** * @return {?} */ getTabBody() { if (this.tabPane !== null && typeof this.tabPane !== 'undefined') { let /** @type {?} */ index = this.tabPane.getTabHeaderIndex(this); return this.tabPane.getTabBody(index); } return null; } /** * @return {?} */ isShowMoreMenu() { return this.showMoreMenu; } /** * @return {?} */ doPreload() { return new Promise((resolve, reject) => { resolve(null); }); } /** * @return {?} */ doLoaded() { } /** * @param {?} $event * @return {?} */ _doFocus($event) { // do something when focus } /** * @param {?} $event * @return {?} */ _doLostFocus($event) { if (this.needFocusService !== null) { this.needFocusService.resetFocusingComponent(this); } } /** * @param {?} event * @return {?} */ onFocus(event) { $(this.elementRef.nativeElement).find(".fake").focus(); } /** * @param {?} event * @return {?} */ onLostFocus(event) { $(this.elementRef.nativeElement).find(".fake").blur(); this.hideMenu(); } } Tab.TYPE_NAME = TYPE_NAME; Tab.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: `<div class="phx-tab table-wrapper"> <div class="table-cell-wrapper middle"> <div *ngIf="getModel() != null" class="phx-tab" [class.dirty]="isDataDirty()" [ngClass]="getModel().styleClass"> <div class="tab-name">{{getTabLabel()}}</div> <div *ngIf="isShowMoreMenu()" class="tab-vertical-ellipsis" (click)="onMoreButtonClick($event)"></div> <phx-context-menu [model]="getModel().menuModel" [context]="this" class="vertical" [autoFocus]="_autoFocus"></phx-context-menu> </div> </div> <button type="button" class="fake" (focusin)="_doFocus($event)" (blur)="_doLostFocus($event)"></button> </div> ` },] }, ]; /** @nocollapse */ Tab.ctorParameters = () => [ { type: ElementRef, }, { type: NeedFocusService, }, ]; Tab.propDecorators = { "model": [{ type: Input },], "tabPane": [{ type: Input },], "menuFactory": [{ type: Input },], "showMoreMenu": [{ type: Input },], "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 },], }; 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); 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.model; /** @type {?} */ Tab.prototype.tabPane; /** @type {?} */ Tab.prototype.contextMenu; /** @type {?} */ Tab.prototype.menuFactory; /** @type {?} */ Tab.prototype.selected; /** @type {?} */ Tab.prototype.showMoreMenu; /** @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.needFocusService; /** @type {?} */ Tab.prototype._autoFocus; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Tab.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/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 { AbstractHasData } from './AbstractHasData';\nimport { AbstractDataView } from './dataview/AbstractDataView';\nimport { Option } from '../decorator/Option.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=\"phx-tab 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\" [context]=\"this\" class=\"vertical\" [autoFocus]=\"_autoFocus\"></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 AbstractHasData implements OnInit, IContext, INeedFocus {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\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  // --- 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  protected needFocusService: NeedFocusService;\n  public _autoFocus: boolean;\n\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService) {\n    super(elementRef);\n    this.showMoreMenu = false;\n    this._autoFocus = 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(): 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> {     return new Promise((resolve, reject) => {       resolve(null);     });   }  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    $(this.elementRef.nativeElement).find(\".fake\").blur();\n    this.hideMenu();\n  }\n}\n"]}