com.phloxui
Version:
PhloxUI Ng2+ Framework
559 lines (558 loc) • 49.6 kB
JavaScript
/**
* @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"]}