@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
395 lines • 50.2 kB
JavaScript
import * as tslib_1 from "tslib";
/**
* Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.
* @link https://truedirective.com/
* @license MIT
*/
import { Component, Input, Output, EventEmitter, Renderer2, ElementRef, ViewChild, forwardRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { DropdownBaseComponent } from './dropdown-base.component';
import { GridSettings, GridState } from '@true-directive/base';
import { GridComponent } from '../grid.component';
import { Keys, Utils } from '@true-directive/base';
var SelectComponent = /** @class */ (function (_super) {
tslib_1.__extends(SelectComponent, _super);
function SelectComponent(_elementRef, _renderer) {
var _this = _super.call(this, _elementRef, _renderer) || this;
_this._elementRef = _elementRef;
_this._renderer = _renderer;
/**
* Current text value
*/
_this.displayValue = '';
// Запрос данных
_this.dataQuery = new EventEmitter();
_this._focusedValue = null;
_this._valueField = null;
_this._displayField = null;
_this.columns = [];
_this.parentState = null;
_this._settings = null;
_this.itemSelect = new EventEmitter();
// Выбираем ли мы из грида
_this._onGrid = false;
_this._empty = false;
_this._updating = false;
_this.useAltDown = false;
return _this;
}
SelectComponent_1 = SelectComponent;
Object.defineProperty(SelectComponent.prototype, "value", {
get: function () {
return this._value;
},
/**
* Current value
*/
set: function (v) {
if (v !== this._value) {
this._value = v;
this.writeValue(this._value);
this.onChange(v);
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(SelectComponent.prototype, "valueField", {
get: function () {
if (this._valueField === null && this.columns.length > 0) {
return this.columns[0].fieldName;
}
return this._valueField === null ? 'id' : this._valueField;
},
set: function (fieldName) {
this._valueField = fieldName;
if (this._settings) {
// Настройки могут быть еще не созданы
this._settings.keyField = this._valueField;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(SelectComponent.prototype, "displayField", {
get: function () {
if (this._displayField === null && this.columns.length > 0) {
return this.columns[0].fieldName;
}
return this._displayField === null ? 'name' : this._displayField;
},
set: function (fieldName) {
this._displayField = fieldName;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SelectComponent.prototype, "settings", {
get: function () {
if (!this._settings) {
this._settings = GridSettings.minimal();
this._settings.keyField = this.valueField;
this._settings.widthUnit = 'em';
this._settings.showHeader = false;
this._settings.columnAutoWidth = false;
this._settings.enableTouchScroll = false;
this._settings.appearance.enableHoverAppearance = true;
}
return this._settings;
},
set: function (v) {
this._settings = v;
this._settings.enableTouchScroll = false;
},
enumerable: true,
configurable: true
});
SelectComponent.prototype.gridStartProcess = function (e) {
if (this._empty && this.settings.requestData) {
this._empty = false;
this._updating = true;
}
};
SelectComponent.prototype.gridEndProcess = function (e) {
var _this = this;
setTimeout(function () {
if (!_this.popup.visible) {
_this.showByTarget();
}
else {
// Let's update position of popup window. When list reduce, it may move
// up or down regarding input.
_this.popup.updatePosition();
}
});
this._updating = false;
if (this.grid.resultRows.length === 0) {
this._empty = true;
}
else {
this._empty = false;
}
};
SelectComponent.prototype.gridDataQuery = function (e) {
this.dataQuery.emit(e);
};
// Отображаем значение в компоненте. Formatter: Ctrl --> View
SelectComponent.prototype.writeValue = function (v) {
var _this = this;
this._value = v;
var found = this.items.find(function (item) { return item[_this.valueField] === v; });
if (!found) {
this.displayValue = '';
}
else {
this.displayValue = found[this.displayField];
}
};
// За один раз устанавливаем и значение и отображение
SelectComponent.prototype.setValue = function (value, displayValue) {
if (value !== this._value || displayValue !== this.displayValue) {
this._focusedValue = value;
this.displayValue = displayValue;
this.value = value;
}
};
// По введенному тексту ничего не найдено?
SelectComponent.prototype.empty = function () {
return this._empty;
};
// Происходит обновление данных?
SelectComponent.prototype.updating = function () {
return this._updating;
};
// Ответ
SelectComponent.prototype.fetchData = function (dataQuery, data) {
var sel = this.getSelectedRow();
if (sel) {
this._focusedValue = sel[this.valueField];
}
if (this.grid && this.popupVisible) {
this.grid.fetchData(dataQuery, data);
if (this._focusedValue) {
this.grid.locateByKey(this._focusedValue);
}
else {
if (this._value !== null) {
this.grid.locateByKey(this._value);
}
}
}
};
/**
* Общая ширина грида в выпадающем списке
* @return Ширина в заданных единицах измерения
*/
SelectComponent.prototype.gridWidth = function () {
var ww = 0;
this.columns.forEach(function (c) { return ww += c.width; });
return ww + this.settings.widthUnit;
};
/**
* Перекрываем показывание выпадающего окна, чтобы обновить вью грида
* и выделить строку, содержащую текущее значение
* @param e Параметры события
*/
SelectComponent.prototype.popupShow = function (e) {
this._onGrid = false;
if (this._value !== null) {
this.grid.locateByKey(this._value, this.valueField);
}
else {
if (this.shownByKey) {
this.grid.processKey(Keys.generateEvent(null, Keys.DOWN)); // Будет выбрана первая запись
}
}
this.grid.checkSize();
};
/**
* Обработчик клавиш вызывается из родительского класса
* Возвращает false, если клавиша не обработана
*/
SelectComponent.prototype.processKey = function (e) {
if (e.keyCode === Keys.ENTER) {
this.setValueFromGrid();
this.popup.closePopup();
return true;
}
if (!this.popupVisible) {
return false;
}
if (e.keyCode === Keys.ESCAPE) {
this.popup.closePopup();
e.preventDefault();
e.stopPropagation();
return true;
}
if (e.keyCode === Keys.DOWN || e.keyCode === Keys.UP) {
this._onGrid = true;
this.grid.processKey(e);
e.preventDefault();
return true;
}
return false;
};
// Клик по записи в гриде
SelectComponent.prototype.gridRowClick = function (e) {
this._onGrid = true;
this._skipFocusOnPopupClose = false;
this.value = e.row[this.valueField];
this.popup.closePopup();
this.itemSelect.emit(e.row);
};
// Поворот иконки
SelectComponent.prototype.iconClass = function () {
var s = 'true-icon-angle-down true-turnable';
if (this.popupVisible) {
s += ' true-turned';
}
return s;
};
// Ввод текста пользователем
SelectComponent.prototype.inputInput = function (e) {
var _this = this;
if (e === void 0) { e = null; }
// Окошко еще на выпало? показываем
if (!this.popupVisible && this.displayValue !== '') {
this.grid.searchString = this.displayValue;
return;
}
if (this.popupVisible) {
setTimeout(function () {
// Устанавливаем фильтр по тексту
_this.grid.searchString = _this.displayValue;
});
}
if (this.displayValue === '') {
this.setValue(null, '');
return;
}
this._value = null;
};
// Возврат выбранной строки в гриде
SelectComponent.prototype.getSelectedRow = function () {
if (this.grid && this.grid.state.selection.ranges.length > 0) {
var item = this.grid.state.selection.ranges[0].fromCell.row;
return item;
}
return null;
};
SelectComponent.prototype.containsDisplayed = function (s) {
return !this.displayValue || (s !== undefined && s.toLowerCase().indexOf(this.displayValue.toLowerCase()) >= 0);
};
// Установка значения по выделенной в гриде записи
SelectComponent.prototype.setValueFromGrid = function () {
var _this = this;
if (!this.popupVisible && this.grid.state.model) {
var found = this.grid.state.model.find(function (item) { return item[_this.displayField].toLowerCase() === _this.displayValue.toLowerCase(); });
if (found) {
this.setValue(found[this.valueField], found[this.displayField]);
}
else {
this.setValue(null, '');
}
return;
}
var sel = this.getSelectedRow();
if (sel && (this._onGrid || this.containsDisplayed(sel[this.displayField]))) {
this.setValue(sel[this.valueField], sel[this.displayField]);
}
else {
this.setValueFromDisplayed();
}
};
/**
* Установка значения по введенному тексту
*/
SelectComponent.prototype.setValueFromDisplayed = function () {
var _this = this;
// По запросу. Смотрим в гриде. Хотя, если подумать, можно всегда в гриде смотреть..
var f = null;
if (this.grid && this.grid.resultRows) {
f = this.grid.resultRows.find(function (item) { return item[_this.displayField].toLowerCase() === _this.displayValue.toLowerCase(); });
}
if (f) {
this.setValue(f[this.valueField], f[this.displayField]);
}
else {
this.setValue(null, '');
}
return;
};
/**
* Потеря фокуса инпутом
* @param e Параметры события
*/
SelectComponent.prototype.inputBlur = function (e) {
this._skipFocusOnPopupClose = true;
if ((this.value === null || this.value === undefined) && this.displayValue !== '') {
if (e.relatedTarget && Utils.isAncestor(this.popup.elementRef.nativeElement, e.relatedTarget)) {
// Если фокус перешел на...
return;
}
this.closePopup();
this.setValueFromDisplayed();
}
_super.prototype.inputBlur.call(this, e);
};
var SelectComponent_1;
tslib_1.__decorate([
Output('dataQuery'),
tslib_1.__metadata("design:type", EventEmitter)
], SelectComponent.prototype, "dataQuery", void 0);
tslib_1.__decorate([
Input('valueField'),
tslib_1.__metadata("design:type", String),
tslib_1.__metadata("design:paramtypes", [String])
], SelectComponent.prototype, "valueField", null);
tslib_1.__decorate([
Input('displayField'),
tslib_1.__metadata("design:type", String),
tslib_1.__metadata("design:paramtypes", [String])
], SelectComponent.prototype, "displayField", null);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Array)
], SelectComponent.prototype, "columns", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", Array)
], SelectComponent.prototype, "items", void 0);
tslib_1.__decorate([
Input(),
tslib_1.__metadata("design:type", GridState)
], SelectComponent.prototype, "parentState", void 0);
tslib_1.__decorate([
Input('settings'),
tslib_1.__metadata("design:type", Object),
tslib_1.__metadata("design:paramtypes", [Object])
], SelectComponent.prototype, "settings", null);
tslib_1.__decorate([
Output('itemSelect'),
tslib_1.__metadata("design:type", EventEmitter)
], SelectComponent.prototype, "itemSelect", void 0);
tslib_1.__decorate([
ViewChild('grid', { static: true }),
tslib_1.__metadata("design:type", GridComponent)
], SelectComponent.prototype, "grid", void 0);
SelectComponent = SelectComponent_1 = tslib_1.__decorate([
Component({
selector: 'true-select',
template: "\n <true-input-wrapper\n (btnClick)=\"btnClick($event)\"\n [disabled]=\"disabled\"\n class=\"true-select__input\"\n [class.true-input_popup-visible]=\"popupVisible\"\n [icon]=\"iconClass()\">\n <input #input\n [(ngModel)]=\"displayValue\"\n [readonly]=\"disableTextEditor\"\n [attr.disabled]=\"disabled\"\n [class.true-disable-te]=\"disableTextEditor\"\n (input)=\"inputInput($event)\"\n (click)=\"inputClick($event)\"\n (touchstart)=\"inputTouchStart($event)\"\n (touchmove)=\"inputTouchMove($event)\"\n (touchend)=\"inputTouchEnd($event)\"\n (blur)=\"inputBlur($event)\"\n (focus)=\"inputFocus($event)\"\n (keydown)=\"inputKeyDown($event)\"/>\n </true-input-wrapper>\n <true-popup #popup\n (close)=\"popupClose($event)\"\n (show)=\"popupShow($event)\" >\n <true-grid #grid\n [class.true-select__grid_hidden]=\"empty()\"\n class=\"true-select__grid\"\n [maxHeight]=\"maxDropDownHeight\"\n [columns]=\"columns\"\n [data]=\"items\"\n [settings]=\"settings\"\n (dataQuery)=\"gridDataQuery($event)\"\n (startProcess)=\"gridStartProcess($event)\"\n (endProcess)=\"gridEndProcess($event)\"\n (rowClick)=\"gridRowClick($event)\">\n </true-grid>\n <div *ngIf=\"empty()\" class=\"true-select__notfound\" [style.width]=\"gridWidth()\">\u041D\u0438\u0447\u0435\u0433\u043E \u043D\u0435 \u043D\u0430\u0439\u0434\u0435\u043D\u043E</div>\n <div *ngIf=\"updating()\" class=\"true-select__updating\">\u0417\u0430\u0433\u0440\u0443\u0437\u043A\u0430...</div>\n </true-popup>\n ",
providers: [{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return SelectComponent_1; }),
multi: true
}],
styles: ["\n\n .true-select__input {\n width: 100%;\n }\n\n input {\n box-sizing: border-box;\n width: 100%;\n height: 100%;\n }\n\n .true-select__grid_hidden {\n display: none;\n }\n\n .true-select__grid {\n border: none !important;\n cursor: pointer;\n }\n\n .true-select__notfound, .true-select__updating {\n padding: 0.6em;\n box-sizing: border-box;\n color: #aaa;\n }\n "]
}),
tslib_1.__metadata("design:paramtypes", [ElementRef,
Renderer2])
], SelectComponent);
return SelectComponent;
}(DropdownBaseComponent));
export { SelectComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/controls/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.\r\n * @link https://truedirective.com/\r\n * @license MIT\r\n*/\r\nimport { Component, Input, Output, HostBinding, EventEmitter, Renderer2, ElementRef,\r\n         ChangeDetectorRef,\r\n         ViewChild, forwardRef } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nimport { PopupComponent } from './popup.component';\r\nimport { DropdownBaseComponent } from './dropdown-base.component';\r\n\r\nimport { GridSettings, GridState } from '@true-directive/base';\r\nimport { Column, DataQuery } from '@true-directive/base';\r\nimport { GridComponent } from '../grid.component';\r\nimport { Keys, Utils } from '@true-directive/base';\r\n\r\n@Component({\r\n  selector: 'true-select',\r\n  template:`\r\n      <true-input-wrapper\r\n        (btnClick)=\"btnClick($event)\"\r\n        [disabled]=\"disabled\"\r\n        class=\"true-select__input\"\r\n        [class.true-input_popup-visible]=\"popupVisible\"\r\n        [icon]=\"iconClass()\">\r\n        <input #input\r\n               [(ngModel)]=\"displayValue\"\r\n               [readonly]=\"disableTextEditor\"\r\n               [attr.disabled]=\"disabled\"\r\n               [class.true-disable-te]=\"disableTextEditor\"\r\n               (input)=\"inputInput($event)\"\r\n               (click)=\"inputClick($event)\"\r\n               (touchstart)=\"inputTouchStart($event)\"\r\n               (touchmove)=\"inputTouchMove($event)\"\r\n               (touchend)=\"inputTouchEnd($event)\"\r\n               (blur)=\"inputBlur($event)\"\r\n               (focus)=\"inputFocus($event)\"\r\n               (keydown)=\"inputKeyDown($event)\"/>\r\n      </true-input-wrapper>\r\n      <true-popup #popup\r\n        (close)=\"popupClose($event)\"\r\n        (show)=\"popupShow($event)\" >\r\n        <true-grid #grid\r\n                 [class.true-select__grid_hidden]=\"empty()\"\r\n                 class=\"true-select__grid\"\r\n                 [maxHeight]=\"maxDropDownHeight\"\r\n                 [columns]=\"columns\"\r\n                 [data]=\"items\"\r\n                 [settings]=\"settings\"\r\n                 (dataQuery)=\"gridDataQuery($event)\"\r\n                 (startProcess)=\"gridStartProcess($event)\"\r\n                 (endProcess)=\"gridEndProcess($event)\"\r\n                 (rowClick)=\"gridRowClick($event)\">\r\n        </true-grid>\r\n        <div *ngIf=\"empty()\" class=\"true-select__notfound\" [style.width]=\"gridWidth()\">Ничего не найдено</div>\r\n        <div *ngIf=\"updating()\" class=\"true-select__updating\">Загрузка...</div>\r\n      </true-popup>\r\n    `,\r\n    /*\r\n      Removed: :host { display: inline-block; } - invalid ios rendering.\r\n     */\r\n  styles: [`\r\n\r\n    .true-select__input {\r\n      width: 100%;\r\n    }\r\n\r\n    input {\r\n      box-sizing: border-box;\r\n      width: 100%;\r\n      height: 100%;\r\n    }\r\n\r\n    .true-select__grid_hidden {\r\n      display: none;\r\n    }\r\n\r\n    .true-select__grid {\r\n      border: none !important;\r\n      cursor: pointer;\r\n    }\r\n\r\n    .true-select__notfound, .true-select__updating {\r\n      padding: 0.6em;\r\n      box-sizing: border-box;\r\n      color: #aaa;\r\n    }\r\n  `],\r\n  providers: [{\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => SelectComponent),\r\n      multi: true}]\r\n  })\r\nexport class SelectComponent extends DropdownBaseComponent {\r\n\r\n  /**\r\n   * Current text value\r\n   */\r\n  public displayValue: string = '';\r\n\r\n  /**\r\n   * Current value\r\n   */\r\n  public set value(v: any) {\r\n    if (v !== this._value) {\r\n      this._value = v;\r\n      this.writeValue(this._value);\r\n      this.onChange(v);\r\n    }\r\n  }\r\n\r\n  public get value() {\r\n    return this._value;\r\n  }\r\n\r\n  // Запрос данных\r\n  @Output('dataQuery')\r\n  dataQuery: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  private _focusedValue: any = null;\r\n  private _valueField: string = null;\r\n\r\n  @Input('valueField')\r\n  public set valueField(fieldName: string) {\r\n    this._valueField = fieldName;\r\n    if (this._settings) {\r\n      // Настройки могут быть еще не созданы\r\n      this._settings.keyField = this._valueField;\r\n    }\r\n  }\r\n\r\n  public get valueField() {\r\n    if (this._valueField === null && this.columns.length > 0) {\r\n      return this.columns[0].fieldName;\r\n    }\r\n    return this._valueField === null ? 'id' : this._valueField;\r\n  }\r\n\r\n  private _displayField: string = null;\r\n  @Input('displayField')\r\n  public set displayField(fieldName: string) {\r\n    this._displayField = fieldName;\r\n  }\r\n\r\n  public get displayField() {\r\n    if (this._displayField === null && this.columns.length > 0) {\r\n      return this.columns[0].fieldName;\r\n    }\r\n    return this._displayField === null ? 'name' : this._displayField;\r\n  }\r\n\r\n  @Input()\r\n  columns: Array<Column> = [];\r\n\r\n  @Input()\r\n  items: Array<any>;\r\n\r\n  @Input()\r\n  parentState: GridState = null;\r\n\r\n  private _settings: GridSettings = null;\r\n\r\n  @Input('settings')\r\n  set settings(v) {\r\n    this._settings = v;\r\n    this._settings.enableTouchScroll = false;\r\n  }\r\n\r\n  get settings() {\r\n    if (!this._settings) {\r\n      this._settings = GridSettings.minimal();\r\n      this._settings.keyField = this.valueField;\r\n      this._settings.widthUnit = 'em';\r\n      this._settings.showHeader = false;\r\n      this._settings.columnAutoWidth = false;\r\n      this._settings.enableTouchScroll = false;\r\n      this._settings.appearance.enableHoverAppearance = true;\r\n    }\r\n    return this._settings;\r\n  }\r\n\r\n  @Output('itemSelect')\r\n  itemSelect: EventEmitter<any> = new EventEmitter();\r\n\r\n  @ViewChild('grid', {static: true})\r\n  grid: GridComponent;\r\n\r\n  // Выбираем ли мы из грида\r\n  _onGrid: boolean = false;\r\n  _empty = false;\r\n\r\n  gridStartProcess(e: any) {\r\n    if (this._empty && this.settings.requestData) {\r\n      this._empty = false;\r\n      this._updating = true;\r\n    }\r\n  }\r\n\r\n  _updating = false;\r\n  gridEndProcess(e: any) {\r\n    setTimeout(() => {\r\n      if (!this.popup.visible) {\r\n        this.showByTarget();\r\n      } else {\r\n        // Let's update position of popup window. When list reduce, it may move\r\n        // up or down regarding input.\r\n        this.popup.updatePosition();\r\n      }\r\n    });\r\n\r\n    this._updating = false;\r\n    if (this.grid.resultRows.length === 0) {\r\n      this._empty = true;\r\n    } else {\r\n      this._empty = false;\r\n    }\r\n  }\r\n\r\n  gridDataQuery(e: any) {\r\n    this.dataQuery.emit(e);\r\n  }\r\n\r\n  // Отображаем значение в компоненте. Formatter: Ctrl --> View\r\n  writeValue(v: any) {\r\n    this._value = v;\r\n    let found = this.items.find(item => item[this.valueField] === v);\r\n    if (!found) {\r\n      this.displayValue = '';\r\n    } else {\r\n      this.displayValue = found[this.displayField];\r\n    }\r\n  }\r\n\r\n  // За один раз устанавливаем и значение и отображение\r\n  setValue(value: any, displayValue: string) {\r\n    if (value !== this._value || displayValue !== this.displayValue) {\r\n      this._focusedValue = value;\r\n      this.displayValue = displayValue;\r\n      this.value = value;\r\n    }\r\n  }\r\n\r\n  // По введенному тексту ничего не найдено?\r\n  empty(): boolean {\r\n    return this._empty;\r\n  }\r\n\r\n  // Происходит обновление данных?\r\n  updating(): boolean {\r\n    return this._updating;\r\n  }\r\n\r\n  // Ответ\r\n  fetchData(dataQuery: DataQuery, data: Array<any>) {\r\n    let sel = this.getSelectedRow();\r\n    if (sel) {\r\n      this._focusedValue = sel[this.valueField];\r\n    }\r\n\r\n    if (this.grid && this.popupVisible) {\r\n      this.grid.fetchData(dataQuery, data);\r\n\r\n      if (this._focusedValue) {\r\n        this.grid.locateByKey(this._focusedValue);\r\n      } else {\r\n        if (this._value !== null) {\r\n          this.grid.locateByKey(this._value);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Общая ширина грида в выпадающем списке\r\n   * @return Ширина в заданных единицах измерения\r\n   */\r\n  gridWidth() {\r\n    let ww = 0;\r\n    this.columns.forEach(c => ww += c.width);\r\n    return ww + this.settings.widthUnit;\r\n  }\r\n\r\n  /**\r\n   * Перекрываем показывание выпадающего окна, чтобы обновить вью грида\r\n   * и выделить строку, содержащую текущее значение\r\n   * @param  e Параметры события\r\n   */\r\n  popupShow(e: any) {\r\n    this._onGrid = false;\r\n\r\n    if (this._value !== null) {\r\n        this.grid.locateByKey(this._value, this.valueField);\r\n    } else {\r\n      if (this.shownByKey) {\r\n        this.grid.processKey(Keys.generateEvent(null, Keys.DOWN)); // Будет выбрана первая запись\r\n      }\r\n    }\r\n    this.grid.checkSize();\r\n  }\r\n\r\n  /**\r\n   * Обработчик клавиш вызывается из родительского класса\r\n   * Возвращает false, если клавиша не обработана\r\n   */\r\n  processKey(e: any): boolean {\r\n\r\n    if (e.keyCode === Keys.ENTER) {\r\n      this.setValueFromGrid();\r\n      this.popup.closePopup();\r\n      return true;\r\n    }\r\n\r\n    if (!this.popupVisible) {\r\n      return false;\r\n    }\r\n\r\n    if (e.keyCode === Keys.ESCAPE) {\r\n      this.popup.closePopup();\r\n      e.preventDefault();\r\n      e.stopPropagation();\r\n      return true;\r\n    }\r\n\r\n    if (e.keyCode === Keys.DOWN || e.keyCode === Keys.UP) {\r\n      this._onGrid = true;\r\n      this.grid.processKey(e);\r\n      e.preventDefault();\r\n      return true;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  // Клик по записи в гриде\r\n  public gridRowClick(e: any) {\r\n    this._onGrid = true;\r\n    this._skipFocusOnPopupClose = false;\r\n    this.value = e.row[this.valueField];\r\n    this.popup.closePopup();\r\n    this.itemSelect.emit(e.row);\r\n  }\r\n\r\n  // Поворот иконки\r\n  public iconClass() {\r\n    let s = 'true-icon-angle-down true-turnable';\r\n    if (this.popupVisible) {\r\n      s += ' true-turned';\r\n    }\r\n    return s;\r\n  }\r\n\r\n  // Ввод текста пользователем\r\n  public inputInput(e: any = null) {\r\n    // Окошко еще на выпало? показываем\r\n    if (!this.popupVisible && this.displayValue !== '') {\r\n      this.grid.searchString = this.displayValue;\r\n      return;\r\n    }\r\n\r\n    if (this.popupVisible) {\r\n      setTimeout(() => {\r\n        // Устанавливаем фильтр по тексту\r\n        this.grid.searchString = this.displayValue;\r\n      });\r\n    }\r\n\r\n    if (this.displayValue === '') {\r\n      this.setValue(null, '');\r\n      return;\r\n    }\r\n\r\n    this._value = null;\r\n  }\r\n\r\n  // Возврат выбранной строки в гриде\r\n  private getSelectedRow(): any {\r\n    if (this.grid && this.grid.state.selection.ranges.length > 0) {\r\n      let item = this.grid.state.selection.ranges[0].fromCell.row;\r\n      return item;\r\n    }\r\n    return null;\r\n  }\r\n\r\n  private containsDisplayed(s: string): boolean {\r\n    return !this.displayValue || (s !== undefined && s.toLowerCase().indexOf(this.displayValue.toLowerCase()) >= 0);\r\n  }\r\n\r\n  // Установка значения по выделенной в гриде записи\r\n  private setValueFromGrid() {\r\n\r\n    if (!this.popupVisible && this.grid.state.model) {\r\n\r\n      const found = this.grid.state.model.find(\r\n          item => item[this.displayField].toLowerCase() === this.displayValue.toLowerCase()\r\n      );\r\n\r\n      if (found) {\r\n        this.setValue(found[this.valueField], found[this.displayField]);\r\n      } else {\r\n        this.setValue(null, '');\r\n      }\r\n      return;\r\n    }\r\n\r\n    const sel = this.getSelectedRow();\r\n    if (sel && (this._onGrid || this.containsDisplayed(sel[this.displayField]))) {\r\n      this.setValue(sel[this.valueField], sel[this.displayField]);\r\n    } else {\r\n      this.setValueFromDisplayed();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Установка значения по введенному тексту\r\n   */\r\n  public setValueFromDisplayed() {\r\n    // По запросу. Смотрим в гриде. Хотя, если подумать, можно всегда в гриде смотреть..\r\n    let f = null;\r\n    if (this.grid && this.grid.resultRows) {\r\n      f = this.grid.resultRows.find(item => item[this.displayField].toLowerCase() === this.displayValue.toLowerCase());\r\n    }\r\n    if (f) {\r\n      this.setValue(f[this.valueField], f[this.displayField]);\r\n    } else {\r\n      this.setValue(null, '');\r\n    }\r\n    return;\r\n  }\r\n\r\n  /**\r\n   * Потеря фокуса инпутом\r\n   * @param  e Параметры события\r\n   */\r\n  inputBlur(e: FocusEvent) {\r\n    this._skipFocusOnPopupClose = true;\r\n    if ((this.value === null || this.value === undefined) && this.displayValue !== '') {\r\n\r\n      if (e.relatedTarget && Utils.isAncestor(this.popup.elementRef.nativeElement, e.relatedTarget)) {\r\n        // Если фокус перешел на...\r\n        return;\r\n      }\r\n\r\n      this.closePopup();\r\n      this.setValueFromDisplayed();\r\n    }\r\n    super.inputBlur(e);\r\n  }\r\n\r\n  constructor(\r\n    protected _elementRef: ElementRef,\r\n    protected _renderer: Renderer2) {\r\n      super(_elementRef, _renderer);\r\n      this.useAltDown = false;\r\n  }\r\n}\r\n"]}