UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

395 lines 50.2 kB
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"]}