UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

559 lines (558 loc) 49.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { EventEmitter } from '@angular/core'; import { AbstractSelectItems } from './AbstractSelectItems'; import { Option } from '../../../decorator/Option.decorator'; import { BEFORE_SHOW_EVENT, SHOW_EVENT, BEFORE_HIDE_EVENT, HIDE_EVENT, BEFORE_CLICK_EVENT, CLICK_EVENT } from '../../../share/CustomEventType'; import { EventUtils } from '../../../share/utils/EventUtils'; const /** @type {?} */ LEFT = "left"; const /** @type {?} */ RIGHT = "right"; const /** @type {?} */ CENTER = "center"; /** * @abstract */ export class AbstractMultiDropdown extends AbstractSelectItems { /** * @param {?} needFocusService * @param {?} elementRef * @param {?} phloxAppInfoService */ constructor(needFocusService, elementRef, phloxAppInfoService) { super(elementRef, needFocusService); this.beforeClickEvent = new EventEmitter(); this.clickEvent = new EventEmitter(); this.beforeShowEvent = new EventEmitter(); this.showEvent = new EventEmitter(); this.beforeHideEvent = new EventEmitter(); this.hideEvent = new EventEmitter(); this.selectEvent = new EventEmitter(); this._isItemClick = false; phloxAppInfoService.getAppInfo().then((info) => { this.phloxAppInfo = info; }); } /** * @param {?} align * @return {?} */ set align(align) { if (align === LEFT || align === RIGHT || align === CENTER) { this._align = align; return; } this._align = null; } /** * @return {?} */ get align() { if (this._align === null || typeof this._align === 'undefined') { return LEFT; } return this._align; } /** * @return {?} */ ngOnInit() { super.ngOnInit(); } /** * @param {?} changes * @return {?} */ ngOnChanges(changes) { // fix bug when set selected before item is not loaded if (changes['items'] !== null && typeof changes['items'] !== 'undefined') { let /** @type {?} */ oldType = changes['items'].previousValue; let /** @type {?} */ newType = changes['items'].currentValue; let /** @type {?} */ oldSize = (oldType !== null && typeof oldType !== 'undefined' && Array.isArray(oldType)) ? oldType.length : 0; let /** @type {?} */ newSize = (newType !== null && typeof newType !== 'undefined' && Array.isArray(newType)) ? newType.length : 0; if (oldSize !== newSize) { if (this.dataParent !== null && this.dataParent !== undefined) { // fix bug setData but still has a bug this.comp.setData() in ngOnInit setTimeout(() => { this.loadedItems(); }, 1); } else { this.loadedItems(); } } } } /** * @return {?} */ scrollToSelectedIndex() { let /** @type {?} */ ele = $(this.elementRef.nativeElement).find('.menu'); let /** @type {?} */ hChild = $(this.elementRef.nativeElement).find('.menu > :eq(0)').outerHeight(); let /** @type {?} */ firstIndex = this.getSelectedIndexes().length > 0 ? this.getSelectedIndexes()[0] : 0; let /** @type {?} */ h = hChild * (firstIndex == 0 ? 0 : firstIndex - 1); if (!(ele.scrollTop() >= (h - ele.height() + hChild + hChild) && ele.scrollTop() <= (h + hChild))) { ele.stop().animate({ scrollTop: h }, 1, 'swing', function () { ele.css({ transition: "all 60ms cubic-bezier(0.175, 0.885, 0.32, 1.275)" }); ele.scrollTop(h); }); } } /** * @param {?} $event * @return {?} */ emitBeforeClickEvent($event) { let /** @type {?} */ sItem = this.getSelectedItems(); let /** @type {?} */ sIndex = this.getSelectedIndexes(); let /** @type {?} */ data = { item: sItem, index: sIndex }; let /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_CLICK_EVENT, this, data, $event); this.beforeClickEvent.emit(ev); } /** * @param {?} $event * @return {?} */ emitClickEvent($event) { let /** @type {?} */ sItem = this.getSelectedItems(); let /** @type {?} */ sIndex = this.getSelectedIndexes(); let /** @type {?} */ data = { item: sItem, index: sIndex }; let /** @type {?} */ ev = EventUtils.newCustomEvent(CLICK_EVENT, this, data, $event); this.clickEvent.emit(ev); } /** * @param {?} $event * @return {?} */ emitBeforeShowEvent($event) { let /** @type {?} */ sItem = this.getSelectedItems(); let /** @type {?} */ sIndex = this.getSelectedIndexes(); let /** @type {?} */ data = { item: sItem, index: sIndex }; let /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_SHOW_EVENT, this, data, $event); this.beforeShowEvent.emit(ev); } /** * @param {?} $event * @return {?} */ emitShowEvent($event) { let /** @type {?} */ sItem = this.getSelectedItems(); let /** @type {?} */ sIndex = this.getSelectedIndexes(); let /** @type {?} */ data = { item: sItem, index: sIndex }; let /** @type {?} */ ev = EventUtils.newCustomEvent(SHOW_EVENT, this, data, $event); this.showEvent.emit(ev); } /** * @param {?} $event * @return {?} */ emitBeforeHideEvent($event) { let /** @type {?} */ sItem = this.getSelectedItems(); let /** @type {?} */ sIndex = this.getSelectedIndexes(); let /** @type {?} */ data = { item: sItem, index: sIndex }; let /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_HIDE_EVENT, this, data, $event); this.beforeHideEvent.emit(ev); } /** * @param {?} $event * @return {?} */ emitHideEvent($event) { let /** @type {?} */ sItem = this.getSelectedItems(); let /** @type {?} */ sIndex = this.getSelectedIndexes(); let /** @type {?} */ data = { item: sItem, index: sIndex }; let /** @type {?} */ ev = EventUtils.newCustomEvent(HIDE_EVENT, this, data, $event); this.hideEvent.emit(ev); } /** * @param {?=} $event * @param {?=} fireEvent * @return {?} */ doShow($event, fireEvent) { if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeShowEvent', $event, fireEvent, ($event) => { // doEvent this.show = true; this.scrollToSelectedIndex(); if (this.needFocusService) { this.needFocusService.setFocusingComponent(this, $event); } }, ($event) => { // emitBeforeEvent this.emitBeforeShowEvent($event); }, ($event, result) => { // emitAfterEvent this.emitShowEvent($event); }, ($event) => { // doPrevented }); } /** * @param {?=} $event * @param {?=} fireEvent * @return {?} */ doHide($event, fireEvent) { if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeHideEvent', $event, fireEvent, ($event) => { // doEvent this.show = false; }, ($event) => { // emitBeforeEvent this.emitBeforeHideEvent($event); }, ($event, result) => { // emitAfterEvent this.emitHideEvent($event); }, ($event) => { // doPrevented }); } /** * @return {?} */ getUIUpdateInterval() { if (this.phloxAppInfo === null || this.phloxAppInfo === undefined) { return 600; } if (this.phloxAppInfo.settings === null || this.phloxAppInfo.settings === undefined) { return 600; } if (this.phloxAppInfo.settings.UI_ANIMATE_INTERVAL === null || this.phloxAppInfo.settings.UI_ANIMATE_INTERVAL === undefined) { return 600; } return this.phloxAppInfo.settings.UI_ANIMATE_INTERVAL; } /** * @param {?=} $event * @param {?=} fireEvent * @return {?} */ click($event, fireEvent) { if (this.isReadOnly()) { return; } if (this.isDisabled()) { return; } if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeClickEvent', $event, fireEvent, ($event) => { // doEvent this.setShow(true); }, ($event) => { // emitBeforeEvent this.emitBeforeClickEvent($event); }, ($event, result) => { // emitAfterEvent this.emitClickEvent($event); }, ($event) => { // doPrevented }); } /** * @param {?} $event * @param {?} index * @return {?} */ onSelectItemClicked($event, index) { this._isItemClick = true; let /** @type {?} */ oldIndexes = this.getSelectedIndexes(); let /** @type {?} */ item = this.getItemAtIndex(index); let /** @type {?} */ oldDatas = []; let /** @type {?} */ newDatas = []; if (oldIndexes !== null && oldIndexes !== undefined) { for (let /** @type {?} */ oldIndex of oldIndexes) { oldDatas.push(this.getItemAtIndex(oldIndex)); newDatas.push(this.getItemAtIndex(oldIndex)); } } if (oldDatas.indexOf(item) === -1) { newDatas.push(item); } else { newDatas.splice(oldDatas.indexOf(item), 1); } this.setSelectedItems(newDatas); } /** * @param {?} $event * @return {?} */ doFocus($event) { } /** * @param {?} $event * @return {?} */ doLostFocus($event) { this.setShow(false); } /** * @param {?} $event * @return {?} */ onFocusing($event) { this.needFocusService.setFocusingComponent(this, $event); } /** * @param {?} $event * @return {?} */ onLostFocusing($event) { if ($event !== undefined && $event !== null) { $event.preventDefault(); } if (this._itemLostFocusingTimeout !== null && typeof this._itemLostFocusingTimeout !== 'undefined') { clearTimeout(this._itemLostFocusingTimeout); this._itemLostFocusingTimeout = null; } this._itemLostFocusingTimeout = setTimeout(() => { if (!this._isItemClick) { this.doBlur($event); this.needFocusService.resetFocusingComponent($event); } else { this.doFocus($event); } this._isItemClick = false; }, 20); // if dropdown not hide try to adjust this value } /** * @param {?} show * @param {?=} $event * @param {?=} fireEvent * @return {?} */ setShow(show, $event, fireEvent) { if (show === null || typeof show !== 'boolean') { show = false; } if (this.show === show) { return; } if (show) { this.doShow($event, fireEvent); } else { this.doHide($event, fireEvent); } } /** * @return {?} */ isShow() { return this.show; } /** * @return {?} */ getAlign() { return this.align; } /** * @param {?} align * @return {?} */ setAlign(align) { this.align = align; } /** * @return {?} */ getDropdownWidth() { return this.dropdownWidth; } /** * @param {?} dropdownWidth * @return {?} */ setDropdownWidth(dropdownWidth) { this.dropdownWidth = dropdownWidth; } /** * @return {?} */ getDropdownHeight() { return this.dropdownHeight; } /** * @param {?} dropdownHeight * @return {?} */ setDropdownHeight(dropdownHeight) { this.dropdownHeight = dropdownHeight; } /** * @return {?} */ getClickEvent() { return this.clickEvent; } /** * @param {?} event * @return {?} */ setClickEvent(event) { this.clickEvent = event; } /** * @return {?} */ getBeforeClickEvent() { return this.beforeClickEvent; } /** * @param {?} event * @return {?} */ setBeforeClickEvent(event) { this.beforeClickEvent = event; } /** * @return {?} */ getShowEvent() { return this.showEvent; } /** * @param {?} event * @return {?} */ setShowEvent(event) { this.showEvent = event; } /** * @return {?} */ getSelectEvent() { return this.selectEvent; } /** * @param {?} event * @return {?} */ setSelectEvent(event) { this.selectEvent = event; } /** * @param {?} data * @return {?} */ setData(data) { super.setData(data); this.setPreloadData(data); } } AbstractMultiDropdown.LEFT = LEFT; AbstractMultiDropdown.RIGHT = RIGHT; AbstractMultiDropdown.CENTER = CENTER; tslib_1.__decorate([ Option('beforeClick'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractMultiDropdown.prototype, "beforeClickEvent", void 0); tslib_1.__decorate([ Option('click'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractMultiDropdown.prototype, "clickEvent", void 0); tslib_1.__decorate([ Option('beforeShow'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractMultiDropdown.prototype, "beforeShowEvent", void 0); tslib_1.__decorate([ Option('show'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractMultiDropdown.prototype, "showEvent", void 0); tslib_1.__decorate([ Option('beforeHide'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractMultiDropdown.prototype, "beforeHideEvent", void 0); tslib_1.__decorate([ Option('hide'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractMultiDropdown.prototype, "hideEvent", void 0); tslib_1.__decorate([ Option('select'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractMultiDropdown.prototype, "selectEvent", void 0); function AbstractMultiDropdown_tsickle_Closure_declarations() { /** @type {?} */ AbstractMultiDropdown.LEFT; /** @type {?} */ AbstractMultiDropdown.RIGHT; /** @type {?} */ AbstractMultiDropdown.CENTER; /** @type {?} */ AbstractMultiDropdown.prototype.needFocusService; /** @type {?} */ AbstractMultiDropdown.prototype.data; /** @type {?} */ AbstractMultiDropdown.prototype.dataParent; /** @type {?} */ AbstractMultiDropdown.prototype.items; /** @type {?} */ AbstractMultiDropdown.prototype.dataComparator; /** @type {?} */ AbstractMultiDropdown.prototype.field; /** @type {?} */ AbstractMultiDropdown.prototype.beforeClickEvent; /** @type {?} */ AbstractMultiDropdown.prototype.clickEvent; /** @type {?} */ AbstractMultiDropdown.prototype.beforeShowEvent; /** @type {?} */ AbstractMultiDropdown.prototype.showEvent; /** @type {?} */ AbstractMultiDropdown.prototype.beforeHideEvent; /** @type {?} */ AbstractMultiDropdown.prototype.hideEvent; /** @type {?} */ AbstractMultiDropdown.prototype.selectEvent; /** @type {?} */ AbstractMultiDropdown.prototype._align; /** @type {?} */ AbstractMultiDropdown.prototype.dropdownWidth; /** @type {?} */ AbstractMultiDropdown.prototype.dropdownHeight; /** @type {?} */ AbstractMultiDropdown.prototype.phloxAppInfo; /** @type {?} */ AbstractMultiDropdown.prototype._isItemClick; /** @type {?} */ AbstractMultiDropdown.prototype._itemLostFocusingTimeout; /** @type {?} */ AbstractMultiDropdown.prototype.show; /** * @abstract * @param {?} $event * @return {?} */ AbstractMultiDropdown.prototype.doBlur = function ($event) { }; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractMultiDropdown.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/dataview/input/AbstractMultiDropdown.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, Output, Type, EventEmitter, ViewChild, OnChanges } from '@angular/core';\r\nimport { AbstractSelectItems } from './AbstractSelectItems';\r\nimport { INeedFocus } from '../../INeedFocus';\r\nimport { IHasData } from '../../IHasData';\r\nimport { IDataComparator } from '../../IDataComparator';\r\nimport { NeedFocusService, PhloxAppInfoService } from '../../../service/services';\r\nimport { DefaultSelectItemModel } from '../../model/DefaultSelectItemModel';\r\nimport { Option } from '../../../decorator/Option.decorator';\r\nimport { PhloxAppInfo } from '../../../component/model/PhloxAppInfo';\r\nimport {\r\n  BEFORE_SHOW_EVENT, SHOW_EVENT, BEFORE_HIDE_EVENT, HIDE_EVENT, BEFORE_CLICK_EVENT, CLICK_EVENT,\r\n  BEFORE_SELECT_EVENT, SELECT_EVENT\r\n} from '../../../share/CustomEventType';\r\nimport { EventUtils } from '../../../share/utils/EventUtils';\r\n\r\nconst LEFT: string = \"left\";\r\nconst RIGHT: string = \"right\";\r\nconst CENTER: string = \"center\";\r\n\r\nexport abstract class AbstractMultiDropdown extends AbstractSelectItems implements OnInit, INeedFocus, OnChanges {\r\n\r\n  public static readonly LEFT: string = LEFT;\r\n  public static readonly RIGHT: string = RIGHT;\r\n  public static readonly CENTER: string = CENTER;\r\n\r\n  protected needFocusService: NeedFocusService;\r\n  protected data: any;\r\n  protected dataParent: IHasData;\r\n  protected items: DefaultSelectItemModel[];\r\n  protected dataComparator: IDataComparator<any>;\r\n  protected field: string;\r\n  @Option('beforeClick')\r\n  protected beforeClickEvent: EventEmitter<any>;\r\n  @Option('click')\r\n  protected clickEvent: EventEmitter<any>;\r\n  @Option('beforeShow')\r\n  protected beforeShowEvent: EventEmitter<any>;\r\n  @Option('show')\r\n  protected showEvent: EventEmitter<any>;\r\n  @Option('beforeHide')\r\n  protected beforeHideEvent: EventEmitter<any>;\r\n  @Option('hide')\r\n  protected hideEvent: EventEmitter<any>;\r\n  @Option('select')\r\n  protected selectEvent: EventEmitter<any>;\r\n  protected _align: string;\r\n  protected dropdownWidth: string;\r\n  protected dropdownHeight: string;\r\n  protected phloxAppInfo: PhloxAppInfo;\r\n  protected _isItemClick: boolean;\r\n  protected _itemLostFocusingTimeout: any;\r\n\r\n  private show: boolean;\r\n\r\n  protected set align(align: string) {\r\n    if (align === LEFT || align === RIGHT || align === CENTER) {\r\n      this._align = align;\r\n      return;\r\n    }\r\n    this._align = null;\r\n  }\r\n\r\n  protected get align(): string {\r\n    if (this._align === null || typeof this._align === 'undefined') {\r\n      return LEFT;\r\n    }\r\n    return this._align;\r\n  }\r\n\r\n  constructor(needFocusService: NeedFocusService, elementRef: ElementRef, phloxAppInfoService: PhloxAppInfoService) {\r\n    super(elementRef, needFocusService);\r\n\r\n    this.beforeClickEvent = new EventEmitter();\r\n    this.clickEvent = new EventEmitter();\r\n    this.beforeShowEvent = new EventEmitter();\r\n    this.showEvent = new EventEmitter();\r\n    this.beforeHideEvent = new EventEmitter();\r\n    this.hideEvent = new EventEmitter();\r\n    this.selectEvent = new EventEmitter();\r\n\r\n    this._isItemClick = false;\r\n\r\n    phloxAppInfoService.getAppInfo().then((info) => {\r\n      this.phloxAppInfo = info;\r\n    });\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n  }\r\n\r\n  public ngOnChanges(changes: any) {\r\n    // fix bug when set selected before item is not loaded\r\n    if (changes['items'] !== null && typeof changes['items'] !== 'undefined') {\r\n      let oldType = changes['items'].previousValue;\r\n      let newType: any = changes['items'].currentValue;\r\n\r\n      let oldSize = (oldType !== null && typeof oldType !== 'undefined' && Array.isArray(oldType)) ? oldType.length : 0;\r\n      let newSize = (newType !== null && typeof newType !== 'undefined' && Array.isArray(newType)) ? newType.length : 0;\r\n\r\n      if (oldSize !== newSize) {\r\n        if (this.dataParent !== null && this.dataParent !== undefined) {\r\n          // fix bug setData but still has a bug this.comp.setData() in ngOnInit\r\n          setTimeout(() => {\r\n            this.loadedItems();\r\n          }, 1);\r\n        }else {\r\n          this.loadedItems();\r\n        }\r\n      }\r\n\r\n    }\r\n  }\r\n\r\n  private scrollToSelectedIndex(): void {\r\n    let ele = $(this.elementRef.nativeElement).find('.menu');\r\n    let hChild = $(this.elementRef.nativeElement).find('.menu > :eq(0)').outerHeight();\r\n\r\n    let firstIndex: number = this.getSelectedIndexes().length > 0 ? this.getSelectedIndexes()[0] : 0;\r\n    let h = hChild * (firstIndex == 0 ? 0 : firstIndex - 1);\r\n\r\n    if (!(ele.scrollTop() >= (h - ele.height() + hChild + hChild) && ele.scrollTop() <= (h + hChild))) {\r\n      ele.stop().animate({ scrollTop: h }, 1, 'swing', function() {\r\n        ele.css({\r\n          transition: \"all 60ms cubic-bezier(0.175, 0.885, 0.32, 1.275)\"\r\n        });\r\n        ele.scrollTop(h);\r\n      });\r\n    }\r\n  }\r\n\r\n  protected emitBeforeClickEvent($event: Event): void {\r\n    let sItem = this.getSelectedItems();\r\n    let sIndex = this.getSelectedIndexes();\r\n\r\n    let data: any = {\r\n      item: sItem,\r\n      index: sIndex\r\n    };\r\n\r\n    let ev = EventUtils.newCustomEvent(BEFORE_CLICK_EVENT, this, data, $event);\r\n\r\n    this.beforeClickEvent.emit(ev);\r\n  }\r\n\r\n  protected emitClickEvent($event: Event): void {\r\n    let sItem = this.getSelectedItems();\r\n    let sIndex = this.getSelectedIndexes();\r\n\r\n    let data: any = {\r\n      item: sItem,\r\n      index: sIndex\r\n    };\r\n\r\n    let ev = EventUtils.newCustomEvent(CLICK_EVENT, this, data, $event);\r\n\r\n    this.clickEvent.emit(ev);\r\n  }\r\n\r\n  protected emitBeforeShowEvent($event: Event): void {\r\n    let sItem = this.getSelectedItems();\r\n    let sIndex = this.getSelectedIndexes();\r\n\r\n    let data: any = {\r\n      item: sItem,\r\n      index: sIndex\r\n    };\r\n\r\n    let ev = EventUtils.newCustomEvent(BEFORE_SHOW_EVENT, this, data, $event);\r\n\r\n    this.beforeShowEvent.emit(ev);\r\n  }\r\n\r\n  protected emitShowEvent($event: Event): void {\r\n    let sItem = this.getSelectedItems();\r\n    let sIndex = this.getSelectedIndexes();\r\n\r\n    let data: any = {\r\n      item: sItem,\r\n      index: sIndex\r\n    };\r\n\r\n    let ev = EventUtils.newCustomEvent(SHOW_EVENT, this, data, $event);\r\n\r\n    this.showEvent.emit(ev);\r\n  }\r\n\r\n  protected emitBeforeHideEvent($event: Event): void {\r\n    let sItem = this.getSelectedItems();\r\n    let sIndex = this.getSelectedIndexes();\r\n\r\n    let data: any = {\r\n      item: sItem,\r\n      index: sIndex\r\n    };\r\n\r\n    let ev = EventUtils.newCustomEvent(BEFORE_HIDE_EVENT, this, data, $event);\r\n\r\n    this.beforeHideEvent.emit(ev);\r\n  }\r\n\r\n  protected emitHideEvent($event: Event): void {\r\n    let sItem = this.getSelectedItems();\r\n    let sIndex = this.getSelectedIndexes();\r\n\r\n    let data: any = {\r\n      item: sItem,\r\n      index: sIndex\r\n    };\r\n\r\n    let ev = EventUtils.newCustomEvent(HIDE_EVENT, this, data, $event);\r\n\r\n    this.hideEvent.emit(ev);\r\n  }\r\n\r\n  private doShow($event?: Event, fireEvent?: boolean): void {\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    EventUtils.handleBrowserEvent(this, 'beforeShowEvent', $event, fireEvent, ($event: Event) => {\r\n      // doEvent\r\n      this.show = true;\r\n\r\n      this.scrollToSelectedIndex();\r\n\r\n      if (this.needFocusService) {\r\n        this.needFocusService.setFocusingComponent(this, $event);\r\n      }\r\n    }, ($event: Event) => {\r\n      // emitBeforeEvent\r\n      this.emitBeforeShowEvent($event);\r\n    }, ($event: Event, result: any) => {\r\n      // emitAfterEvent\r\n      this.emitShowEvent($event);\r\n    }, ($event: Event) => {\r\n      // doPrevented\r\n    });\r\n  }\r\n\r\n  private doHide($event?: Event, fireEvent?: boolean): void {\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    EventUtils.handleBrowserEvent(this, 'beforeHideEvent', $event, fireEvent, ($event: Event) => {\r\n      // doEvent\r\n      this.show = false;\r\n    }, ($event: Event) => {\r\n      // emitBeforeEvent\r\n      this.emitBeforeHideEvent($event);\r\n    }, ($event: Event, result: any) => {\r\n      // emitAfterEvent\r\n      this.emitHideEvent($event);\r\n    }, ($event: Event) => {\r\n      // doPrevented\r\n    });\r\n  }\r\n\r\n  protected getUIUpdateInterval(): number {\r\n\r\n    if (this.phloxAppInfo === null || this.phloxAppInfo === undefined) {\r\n      return 600;\r\n    }\r\n    if (this.phloxAppInfo.settings === null || this.phloxAppInfo.settings === undefined) {\r\n      return 600;\r\n    }\r\n    if (this.phloxAppInfo.settings.UI_ANIMATE_INTERVAL === null || this.phloxAppInfo.settings.UI_ANIMATE_INTERVAL === undefined) {\r\n      return 600;\r\n    }\r\n\r\n    return this.phloxAppInfo.settings.UI_ANIMATE_INTERVAL;\r\n  }\r\n\r\n  public click($event?: Event, fireEvent?: boolean) {\r\n    if (this.isReadOnly()) {\r\n      return;\r\n    }\r\n\r\n    if (this.isDisabled()) {\r\n      return;\r\n    }\r\n\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    EventUtils.handleBrowserEvent(this, 'beforeClickEvent', $event, fireEvent, ($event: Event) => {\r\n      // doEvent\r\n      this.setShow(true);\r\n    }, ($event: Event) => {\r\n      // emitBeforeEvent\r\n      this.emitBeforeClickEvent($event);\r\n    }, ($event: Event, result: any) => {\r\n      // emitAfterEvent\r\n      this.emitClickEvent($event);\r\n    }, ($event: Event) => {\r\n      // doPrevented\r\n    });\r\n  }\r\n\r\n  public onSelectItemClicked($event: Event, index: number): void {\r\n    this._isItemClick = true;\r\n\r\n    let oldIndexes: number[] = this.getSelectedIndexes();\r\n\r\n    let item = this.getItemAtIndex(index);\r\n\r\n    let oldDatas: any = [];\r\n    let newDatas: any = [];\r\n\r\n    if (oldIndexes !== null && oldIndexes !== undefined) {\r\n      for (let oldIndex of oldIndexes) {\r\n        oldDatas.push(this.getItemAtIndex(oldIndex));\r\n        newDatas.push(this.getItemAtIndex(oldIndex));\r\n      }\r\n    }\r\n\r\n    if (oldDatas.indexOf(item) === -1) {\r\n      newDatas.push(item);\r\n    } else {\r\n      newDatas.splice(oldDatas.indexOf(item), 1);\r\n    }\r\n\r\n    this.setSelectedItems(newDatas);\r\n  }\r\n\r\n  protected doFocus($event: Event): void {\r\n  }\r\n\r\n  protected doLostFocus($event: Event): void {\r\n    this.setShow(false);\r\n  }\r\n\r\n  public onFocusing($event: Event): void {\r\n    this.needFocusService.setFocusingComponent(this, $event);\r\n  }\r\n\r\n  public onLostFocusing($event: Event): void {\r\n    if ($event !== undefined && $event !== null) {\r\n      $event.preventDefault();\r\n    }\r\n\r\n    if (this._itemLostFocusingTimeout !== null && typeof this._itemLostFocusingTimeout !== 'undefined') {\r\n      clearTimeout(this._itemLostFocusingTimeout);\r\n      this._itemLostFocusingTimeout = null;\r\n    }\r\n\r\n    this._itemLostFocusingTimeout = setTimeout(() => {\r\n      if (!this._isItemClick) {\r\n        this.doBlur($event);\r\n        this.needFocusService.resetFocusingComponent($event);\r\n      } else {\r\n        this.doFocus($event);\r\n      }\r\n      this._isItemClick = false;\r\n    }, 20); // if dropdown not hide try to adjust this value\r\n  }\r\n\r\n  public setShow(show: boolean, $event?: Event, fireEvent?: boolean): void {\r\n    if (show === null || typeof show !== 'boolean') {\r\n      show = false;\r\n    }\r\n    if (this.show === show) {\r\n      return;\r\n    }\r\n\r\n    if (show) {\r\n      this.doShow($event, fireEvent);\r\n    } else {\r\n      this.doHide($event, fireEvent);\r\n    }\r\n  }\r\n\r\n  public isShow(): boolean {\r\n    return this.show;\r\n  }\r\n\r\n  public getAlign(): string {\r\n    return this.align;\r\n  }\r\n\r\n  public setAlign(align: string): void {\r\n    this.align = align;\r\n  }\r\n\r\n  public getDropdownWidth(): string {\r\n    return this.dropdownWidth;\r\n  }\r\n\r\n  public setDropdownWidth(dropdownWidth: string): void {\r\n    this.dropdownWidth = dropdownWidth;\r\n  }\r\n\r\n  public getDropdownHeight(): string {\r\n    return this.dropdownHeight;\r\n  }\r\n\r\n  public setDropdownHeight(dropdownHeight: string): void {\r\n    this.dropdownHeight = dropdownHeight;\r\n  }\r\n\r\n  public getClickEvent(): EventEmitter<any> {\r\n    return this.clickEvent;\r\n  }\r\n\r\n  public setClickEvent(event: EventEmitter<any>): void {\r\n    this.clickEvent = event;\r\n  }\r\n\r\n  public getBeforeClickEvent(): EventEmitter<any> {\r\n    return this.beforeClickEvent;\r\n  }\r\n\r\n  public setBeforeClickEvent(event: EventEmitter<any>): void {\r\n    this.beforeClickEvent = event;\r\n  }\r\n\r\n  public getShowEvent(): EventEmitter<any> {\r\n    return this.showEvent;\r\n  }\r\n\r\n  public setShowEvent(event: EventEmitter<any>): void {\r\n    this.showEvent = event;\r\n  }\r\n\r\n  public getSelectEvent(): EventEmitter<any> {\r\n    return this.selectEvent;\r\n  }\r\n\r\n  public setSelectEvent(event: EventEmitter<any>): void {\r\n    this.selectEvent = event;\r\n  }\r\n\r\n  public setData(data: any): void {\r\n    super.setData(data);\r\n\r\n    this.setPreloadData(data);\r\n  }\r\n\r\n  protected abstract doBlur($event: Event): void;\r\n}\r\n"]}