UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

286 lines 29.7 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 } from '@angular/core'; import { PopupComponent } from './popup.component'; import { Keys, Utils } from '@true-directive/base'; /** * Dropdown base component. */ let DropdownBaseComponent = class DropdownBaseComponent { constructor(_elementRef, _renderer) { this._elementRef = _elementRef; this._renderer = _renderer; this.usePopup = true; this.currentPopupVisible = false; this.disableTextEditor = false; this.disabled = null; this.maxDropDownHeight = '300px'; this.blur = new EventEmitter(); this.keydown = new EventEmitter(); this.onChange = (_) => { }; this.onTouched = () => { }; this._validBlur = false; this._useAltDown = true; this.shownByKey = false; this._touched = false; this._skipFocusOnPopupClose = false; } get popupPosition() { return this.popup.position; } set popupPosition(pos) { this.currentPopupPosition = pos; if (this.popup) { this.popup.position = pos; } } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouched = fn; } set useAltDown(v) { this._useAltDown = v; } get useAltDown() { return this._useAltDown; } fetchData(dataQuery, data) { // } inputBlur(e) { // This touch was accepted this.onTouched(); // We shouldn't close window if the focus is moved to a popup window let l = e.relatedTarget; if (l === null || Utils.isAncestor(this.popup.popup.nativeElement, l)) { // l = null if the focus is moved to a grid because tabIndex = -1 // If the focus is moved to another element, then l != null // If the focus is moved by mouse click, then documentclick event occurs // and popup will be closed. return; } if (l === null || Utils.isAncestor(this._elementRef.nativeElement, l)) { // Window isn't closed if the focus moved to one of child elements return; } // Close the popup window if (this.popup.visible && !this._validBlur) { this._skipFocusOnPopupClose = true; this.popup.closePopup(); } // Reset the flag this._validBlur = false; this.blur.emit(e); } inputClick(e) { // Prevent popup from disabled input if (this.disabled) { return; } if (this.disableTextEditor) { if (this.popupVisible) { this.closePopup(); } else { this.showByTarget(); } e.stopPropagation(); e.preventDefault(); } } inputTouchStart(e) { this._touched = true; if (this.disableTextEditor) { e.stopPropagation(); e.preventDefault(); } } inputTouchMove(e) { this._touched = false; } inputTouchEnd(e) { if (!this.disabled && this.disableTextEditor) { if (!this.popupVisible && this._touched) { // Show the popup window by touchend event this.showByTarget(); if (e.cancelable) { e.preventDefault(); } } e.stopPropagation(); } } get value() { return this._value; } ; set value(v) { if (v !== this._value) { this._value = v; this.onChange(v); } } // Send the value to input. Formatter: Ctrl --> View writeValue(value) { if (this.value !== value) { this.value = value; } } get popupVisible() { if (this.popup) { return this.popup.visible; } return false; } focusPopup() { // } processKey(e) { return false; } showByTarget() { if (!this.usePopup) { return; } this.popup.showByTarget(this.input.nativeElement); } closePopup() { this.popup.closePopup(); } /** * User's input * @param e Input event */ inputInput(e = null) { // } inputKeyDown(e) { if (e.keyCode === Keys.ESCAPE && this.popup.visible) { this.closePopup(); e.stopPropagation(); e.preventDefault(); return; } if (e.keyCode === Keys.DOWN && (e.altKey || !this.useAltDown) && !this.popup.visible) { this.shownByKey = true; this.showByTarget(); setTimeout(() => this.focusPopup()); e.preventDefault(); e.stopPropagation(); return; } if (!this.processKey(e)) { this.keydown.emit(e); } } focus() { this.input.nativeElement.focus(); } popupClose(e) { // Можем пропустить это мероприятие, если мы закрываем выпадающую панель, // находясь в контроле // Skip setting the focus if dropdown is closed. if (this._skipFocusOnPopupClose) { this._skipFocusOnPopupClose = false; return; } if (!Utils.detectMobile()) { // We allow the user to set the focus on input. this.input.nativeElement.focus(); setTimeout(() => { const txt = this.input.nativeElement.value; if (txt !== undefined && !this.disableTextEditor && this._renderer) { this._renderer.setProperty(this.input.nativeElement, 'selectionStart', 0); this._renderer.setProperty(this.input.nativeElement, 'selectionEnd', txt.length); } }); } } inputFocus(e) { if (this.disableTextEditor) { this._renderer.setProperty(this.input.nativeElement, 'selectionStart', 0); this._renderer.setProperty(this.input.nativeElement, 'selectionEnd', 0); } else { const txt = this.input.nativeElement.value; this._renderer.setProperty(this.input.nativeElement, 'selectionStart', 0); this._renderer.setProperty(this.input.nativeElement, 'selectionEnd', txt.length); } } togglePopup() { if (this.disabled) { return; } this.popup.toggle(this.input.nativeElement, ''); setTimeout(() => { if (this.popupVisible) { this.focusPopup(); } }); } btnClick(e) { this.togglePopup(); } setValueFromDisplayed() { // } ngAfterViewInit() { this.popup.position = this.currentPopupPosition; } ngOnDestroy() { if (this.popupVisible) { this.popup.closePopup(); } } }; tslib_1.__decorate([ ViewChild('popup', { static: false }), tslib_1.__metadata("design:type", PopupComponent) ], DropdownBaseComponent.prototype, "popup", void 0); tslib_1.__decorate([ ViewChild('input', { static: true }), tslib_1.__metadata("design:type", Object) ], DropdownBaseComponent.prototype, "input", void 0); tslib_1.__decorate([ Input('disableTextEditor'), tslib_1.__metadata("design:type", Object) ], DropdownBaseComponent.prototype, "disableTextEditor", void 0); tslib_1.__decorate([ Input('disabled'), tslib_1.__metadata("design:type", Boolean) ], DropdownBaseComponent.prototype, "disabled", void 0); tslib_1.__decorate([ Input('maxDropDownHeight'), tslib_1.__metadata("design:type", Object) ], DropdownBaseComponent.prototype, "maxDropDownHeight", void 0); tslib_1.__decorate([ Input('popupPosition'), tslib_1.__metadata("design:type", String), tslib_1.__metadata("design:paramtypes", [String]) ], DropdownBaseComponent.prototype, "popupPosition", null); tslib_1.__decorate([ Output('blur'), tslib_1.__metadata("design:type", EventEmitter) ], DropdownBaseComponent.prototype, "blur", void 0); tslib_1.__decorate([ Output('keydown'), tslib_1.__metadata("design:type", EventEmitter) ], DropdownBaseComponent.prototype, "keydown", void 0); tslib_1.__decorate([ Input('useAltDown'), tslib_1.__metadata("design:type", Boolean), tslib_1.__metadata("design:paramtypes", [Boolean]) ], DropdownBaseComponent.prototype, "useAltDown", null); DropdownBaseComponent = tslib_1.__decorate([ Component({ selector: 'true-drop-down-base', template: ``, styles: [``] }), tslib_1.__metadata("design:paramtypes", [ElementRef, Renderer2]) ], DropdownBaseComponent); export { DropdownBaseComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-base.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/controls/dropdown-base.component.ts"],"names":[],"mappings":";AAAA;;;;EAIE;AACF,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,SAAS,EAAE,UAAU,EAC7D,SAAS,EAA4B,MAAM,eAAe,CAAC;AAEpE,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAEnD,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,sBAAsB,CAAC;AAGnD;;GAEG;AAMH,IAAa,qBAAqB,GAAlC,MAAa,qBAAqB;IAmShC,YACY,WAAuB,EACvB,SAAoB;QADpB,gBAAW,GAAX,WAAW,CAAY;QACvB,cAAS,GAAT,SAAS,CAAW;QAnShC,aAAQ,GAAY,IAAI,CAAC;QAEzB,wBAAmB,GAAG,KAAK,CAAC;QAS5B,sBAAiB,GAAG,KAAK,CAAC;QAG1B,aAAQ,GAAY,IAAI,CAAC;QAGzB,sBAAiB,GAAG,OAAO,CAAC;QAe5B,SAAI,GAAsB,IAAI,YAAY,EAAO,CAAC;QAGlD,YAAO,GAAsB,IAAI,YAAY,EAAO,CAAC;QAE3C,aAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAC;QAC1B,cAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QAKrB,eAAU,GAAG,KAAK,CAAC;QACnB,gBAAW,GAAG,IAAI,CAAC;QAanB,eAAU,GAAG,KAAK,CAAC;QAyDrB,aAAQ,GAAG,KAAK,CAAC;QA4GzB,2BAAsB,GAAG,KAAK,CAAC;IAqEK,CAAC;IA/QrC,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;IAC7B,CAAC;IAED,IAAW,aAAa,CAAC,GAAgD;QACvE,IAAI,CAAC,oBAAoB,GAAG,GAAG,CAAC;QAChC,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG,CAAC;SAC3B;IACH,CAAC;IAWD,gBAAgB,CAAC,EAAoB,IAAU,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC;IACpE,iBAAiB,CAAC,EAAc,IAAU,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC,CAAC,CAAC;IAQhE,IAAW,UAAU,CAAC,CAAU;QAC9B,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;IACvB,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAID,SAAS,CAAC,SAAoB,EAAE,IAAgB;QAC9C,EAAE;IACJ,CAAC;IAED,SAAS,CAAC,CAAa;QAErB,0BAA0B;QAC1B,IAAI,CAAC,SAAS,EAAE,CAAC;QAEjB,oEAAoE;QACpE,IAAI,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC;QACxB,IAAI,CAAC,KAAK,IAAI,IAAI,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,CAAC,EAAE;YAErE,iEAAiE;YACjE,2DAA2D;YAC3D,wEAAwE;YACxE,4BAA4B;YAC5B,OAAO;SACR;QAED,IAAI,CAAC,KAAK,IAAI,IAAI,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,CAAC,CAAC,EAAE;YACrE,kEAAkE;YAClE,OAAO;SACR;QAED,yBAAyB;QACzB,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YAC1C,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;YACnC,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC;SACzB;QAED,iBAAiB;QACjB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QAExB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACpB,CAAC;IAED,UAAU,CAAC,CAAM;QAEf,oCAAoC;QACpC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO;SACR;QAED,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,IAAI,CAAC,YAAY,EAAE;gBACrB,IAAI,CAAC,UAAU,EAAE,CAAC;aACnB;iBAAM;gBACL,IAAI,CAAC,YAAY,EAAE,CAAC;aACrB;YACD,CAAC,CAAC,eAAe,EAAE,CAAC;YACpB,CAAC,CAAC,cAAc,EAAE,CAAC;SACpB;IACH,CAAC;IAGD,eAAe,CAAC,CAAM;QACpB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QAErB,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,CAAC,CAAC,eAAe,EAAE,CAAC;YACpB,CAAC,CAAC,cAAc,EAAE,CAAC;SACpB;IACH,CAAC;IAED,cAAc,CAAC,CAAM;QACnB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,aAAa,CAAC,CAAM;QAElB,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC5C,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACvC,0CAA0C;gBAC1C,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpB,IAAI,CAAC,CAAC,UAAU,EAAE;oBAChB,CAAC,CAAC,cAAc,EAAE,CAAC;iBACpB;aACF;YACD,CAAC,CAAC,eAAe,EAAE,CAAC;SACrB;IACH,CAAC;IAID,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAAA,CAAC;IAEF,IAAW,KAAK,CAAC,CAAM;QACrB,IAAI,CAAC,KAAK,IAAI,CAAC,MAAM,EAAE;YACrB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;YAChB,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;SAClB;IACH,CAAC;IAED,oDAAoD;IACpD,UAAU,CAAC,KAAU;QACnB,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE;YACxB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;SACpB;IACH,CAAC;IAED,IAAI,YAAY;QACd,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC;SAC3B;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAES,UAAU;QAClB,EAAE;IACJ,CAAC;IAES,UAAU,CAAC,CAAM;QACzB,OAAO,KAAK,CAAC;IACf,CAAC;IAEM,YAAY;QACjB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,OAAO;SACR;QACD,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;IACpD,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC;IAC1B,CAAC;IAED;;;OAGG;IACI,UAAU,CAAC,IAAS,IAAI;QAC7B,EAAE;IACJ,CAAC;IAED,YAAY,CAAC,CAAM;QACjB,IAAI,CAAC,CAAC,OAAO,KAAK,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;YACnD,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,CAAC,CAAC,eAAe,EAAE,CAAC;YACpB,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,OAAO;SACR;QAED,IAAI,CAAC,CAAC,OAAO,KAAK,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE;YACpF,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;YACpC,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,CAAC,CAAC,eAAe,EAAE,CAAC;YACpB,OAAO;SACR;QAED,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE;YACvB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SACtB;IACH,CAAC;IAED,KAAK;QACH,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACnC,CAAC;IAGD,UAAU,CAAC,CAAM;QAEf,yEAAyE;QACzE,sBAAsB;QACtB,gDAAgD;QAChD,IAAI,IAAI,CAAC,sBAAsB,EAAE;YAC/B,IAAI,CAAC,sBAAsB,GAAG,KAAK,CAAC;YACpC,OAAO;SACR;QAED,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,EAAE;YACzB,+CAA+C;YAC/C,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YACjC,UAAU,CAAC,GAAG,EAAE;gBACd,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC;gBAC3C,IAAI,GAAG,KAAK,SAAS,IAAI,CAAC,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,SAAS,EAAE;oBAClE,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,gBAAgB,EAAE,CAAC,CAAC,CAAC;oBAC1E,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,cAAc,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;iBAClF;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,UAAU,CAAC,CAAM;QACf,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,gBAAgB,EAAE,CAAC,CAAC,CAAC;YAC1E,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,cAAc,EAAE,CAAC,CAAC,CAAC;SACzE;aAAM;YACL,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC;YAC3C,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,gBAAgB,EAAE,CAAC,CAAC,CAAC;YAC1E,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,cAAc,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;SAClF;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO;SACR;QAED,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC;QAEhD,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,IAAI,CAAC,YAAY,EAAE;gBACrB,IAAI,CAAC,UAAU,EAAE,CAAC;aACnB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ,CAAC,CAAM;QACb,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAEM,qBAAqB;QAC1B,EAAE;IACJ,CAAC;IAED,eAAe;QACb,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,oBAAoB,CAAC;IAClD,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC;SACzB;IACH,CAAC;CAKF,CAAA;AA/RC;IADC,SAAS,CAAC,OAAO,EAAE,EAAC,MAAM,EAAE,KAAK,EAAC,CAAC;sCAC7B,cAAc;oDAAC;AAGtB;IADC,SAAS,CAAC,OAAO,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC,CAAC;;oDACxB;AAGX;IADC,KAAK,CAAC,mBAAmB,CAAC;;gEACD;AAG1B;IADC,KAAK,CAAC,UAAU,CAAC;;uDACO;AAGzB;IADC,KAAK,CAAC,mBAAmB,CAAC;;gEACC;AAG5B;IADC,KAAK,CAAC,eAAe,CAAC;;;0DAGtB;AAUD;IADC,MAAM,CAAC,MAAM,CAAC;sCACT,YAAY;mDAAgC;AAGlD;IADC,MAAM,CAAC,SAAS,CAAC;sCACT,YAAY;sDAAgC;AAcrD;IADC,KAAK,CAAC,YAAY,CAAC;;;uDAGnB;AArDU,qBAAqB;IALjC,SAAS,CAAC;QACT,QAAQ,EAAE,qBAAqB;QAC/B,QAAQ,EAAC,EAAE;iBACF,EAAE;KACZ,CAAC;6CAqSyB,UAAU;QACZ,SAAS;GArSrB,qBAAqB,CAsSjC;SAtSY,qBAAqB","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, EventEmitter, Renderer2, ElementRef,\r\n         ViewChild, OnDestroy, AfterViewInit } from '@angular/core';\r\nimport { ControlValueAccessor } from '@angular/forms';\r\nimport { PopupComponent } from './popup.component';\r\n\r\nimport { Keys, Utils } from '@true-directive/base';\r\nimport { DataQuery } from '@true-directive/base';\r\n\r\n/**\r\n * Dropdown base component.\r\n */\r\n@Component({\r\n  selector: 'true-drop-down-base',\r\n  template:``,\r\n  styles: [``] \r\n})\r\nexport class DropdownBaseComponent implements AfterViewInit, ControlValueAccessor, OnDestroy {\r\n\r\n  usePopup: boolean = true;\r\n  currentPopupPosition: 'RELATIVE' | 'ABSOLUTE' | 'MODAL' | 'SNACK';\r\n  currentPopupVisible = false;\r\n\r\n  @ViewChild('popup', {static: false})\r\n  popup: PopupComponent;\r\n\r\n  @ViewChild('input', {static: true})\r\n  input: any;\r\n\r\n  @Input('disableTextEditor')\r\n  disableTextEditor = false;\r\n\r\n  @Input('disabled')\r\n  disabled: boolean = null;\r\n\r\n  @Input('maxDropDownHeight')\r\n  maxDropDownHeight = '300px';\r\n\r\n  @Input('popupPosition')\r\n  public get popupPosition(): 'RELATIVE' | 'ABSOLUTE' | 'MODAL' | 'SNACK' {\r\n    return this.popup.position;\r\n  }\r\n\r\n  public set popupPosition(pos: 'RELATIVE' | 'ABSOLUTE' | 'MODAL' | 'SNACK') {\r\n    this.currentPopupPosition = pos;\r\n    if (this.popup) {\r\n      this.popup.position = pos;\r\n    }\r\n  }\r\n\r\n  @Output('blur')\r\n  blur: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output('keydown')\r\n  keydown: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  protected onChange = (_: any) => {};\r\n  protected onTouched = () => {};\r\n\r\n  registerOnChange(fn: (_: any) => void): void { this.onChange = fn; }\r\n  registerOnTouched(fn: () => void): void { this.onTouched = fn; }\r\n\r\n  protected _validBlur = false;\r\n  protected _useAltDown = true;\r\n\r\n  public displayValue: string;\r\n\r\n  @Input('useAltDown')\r\n  public set useAltDown(v: boolean) {\r\n    this._useAltDown = v;\r\n  }\r\n\r\n  public get useAltDown(): boolean {\r\n    return this._useAltDown;\r\n  }\r\n\r\n  protected shownByKey = false;\r\n\r\n  fetchData(dataQuery: DataQuery, data: Array<any>) {\r\n    //\r\n  }\r\n\r\n  inputBlur(e: FocusEvent) {\r\n\r\n    // This touch was accepted\r\n    this.onTouched();\r\n\r\n    // We shouldn't close window if the focus is moved to a popup window\r\n    let l = e.relatedTarget;\r\n    if (l === null || Utils.isAncestor(this.popup.popup.nativeElement, l)) {\r\n\r\n      // l = null if the focus is moved to a grid because tabIndex = -1\r\n      // If the focus is moved to another element, then l != null\r\n      // If the focus is moved by mouse click, then documentclick event occurs\r\n      // and popup will be closed.\r\n      return;\r\n    }\r\n\r\n    if (l === null || Utils.isAncestor(this._elementRef.nativeElement, l)) {\r\n      // Window isn't closed if the focus moved to one of child elements\r\n      return;\r\n    }\r\n\r\n    // Close the popup window\r\n    if (this.popup.visible && !this._validBlur) {\r\n      this._skipFocusOnPopupClose = true;\r\n      this.popup.closePopup();\r\n    }\r\n\r\n    // Reset the flag\r\n    this._validBlur = false;\r\n\r\n    this.blur.emit(e);\r\n  }\r\n\r\n  inputClick(e: any) {\r\n\r\n    // Prevent popup from disabled input\r\n    if (this.disabled) {\r\n      return;\r\n    }\r\n\r\n    if (this.disableTextEditor) {\r\n      if (this.popupVisible) {\r\n        this.closePopup();\r\n      } else {\r\n        this.showByTarget();\r\n      }\r\n      e.stopPropagation();\r\n      e.preventDefault();\r\n    }\r\n  }\r\n\r\n  private _touched = false;\r\n  inputTouchStart(e: any) {\r\n    this._touched = true;\r\n\r\n    if (this.disableTextEditor) {\r\n      e.stopPropagation();\r\n      e.preventDefault();\r\n    }\r\n  }\r\n\r\n  inputTouchMove(e: any) {\r\n    this._touched = false;\r\n  }\r\n\r\n  inputTouchEnd(e: any) {\r\n\r\n    if (!this.disabled && this.disableTextEditor) {\r\n      if (!this.popupVisible && this._touched) {\r\n        // Show the popup window by touchend event\r\n        this.showByTarget();\r\n        if (e.cancelable) {\r\n          e.preventDefault();\r\n        }\r\n      }\r\n      e.stopPropagation();\r\n    }\r\n  }\r\n\r\n  protected _value: any;\r\n\r\n  public get value(): any {\r\n    return this._value;\r\n  };\r\n\r\n  public set value(v: any) {\r\n    if (v !== this._value) {\r\n      this._value = v;\r\n      this.onChange(v);\r\n    }\r\n  }\r\n\r\n  // Send the value to input. Formatter: Ctrl --> View\r\n  writeValue(value: any): void {\r\n    if (this.value !== value) {\r\n      this.value = value;\r\n    }\r\n  }\r\n\r\n  get popupVisible(): boolean {    \r\n    if (this.popup) {\r\n      return this.popup.visible;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  protected focusPopup() {\r\n    //\r\n  }\r\n\r\n  protected processKey(e: any) {\r\n    return false;\r\n  }\r\n\r\n  public showByTarget() {\r\n    if (!this.usePopup) {\r\n      return;\r\n    }\r\n    this.popup.showByTarget(this.input.nativeElement);\r\n  }\r\n\r\n  public closePopup() {\r\n    this.popup.closePopup();\r\n  }\r\n\r\n  /**\r\n   * User's input\r\n   * @param  e Input event\r\n   */\r\n  public inputInput(e: any = null) {\r\n    //\r\n  }\r\n\r\n  inputKeyDown(e: any) {\r\n    if (e.keyCode === Keys.ESCAPE && this.popup.visible) {\r\n      this.closePopup();\r\n      e.stopPropagation();\r\n      e.preventDefault();\r\n      return;\r\n    }\r\n\r\n    if (e.keyCode === Keys.DOWN && (e.altKey || !this.useAltDown) && !this.popup.visible) {\r\n      this.shownByKey = true;\r\n      this.showByTarget();\r\n      setTimeout(() => this.focusPopup());\r\n      e.preventDefault();\r\n      e.stopPropagation();\r\n      return;\r\n    }\r\n\r\n    if (!this.processKey(e)) {\r\n      this.keydown.emit(e);\r\n    }\r\n  }\r\n\r\n  focus() {\r\n    this.input.nativeElement.focus();\r\n  }\r\n\r\n  _skipFocusOnPopupClose = false;\r\n  popupClose(e: any) {\r\n\r\n    // Можем пропустить это мероприятие, если мы закрываем выпадающую панель,\r\n    // находясь в контроле\r\n    // Skip setting the focus if dropdown is closed.\r\n    if (this._skipFocusOnPopupClose) {\r\n      this._skipFocusOnPopupClose = false;\r\n      return;\r\n    }\r\n\r\n    if (!Utils.detectMobile()) {\r\n      // We allow the user to set the focus on input.\r\n      this.input.nativeElement.focus();\r\n      setTimeout(() => {\r\n        const txt = this.input.nativeElement.value;\r\n        if (txt !== undefined && !this.disableTextEditor && this._renderer) {\r\n          this._renderer.setProperty(this.input.nativeElement, 'selectionStart', 0);\r\n          this._renderer.setProperty(this.input.nativeElement, 'selectionEnd', txt.length);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  inputFocus(e: any) {\r\n    if (this.disableTextEditor) {\r\n      this._renderer.setProperty(this.input.nativeElement, 'selectionStart', 0);\r\n      this._renderer.setProperty(this.input.nativeElement, 'selectionEnd', 0);\r\n    } else {\r\n      const txt = this.input.nativeElement.value;\r\n      this._renderer.setProperty(this.input.nativeElement, 'selectionStart', 0);\r\n      this._renderer.setProperty(this.input.nativeElement, 'selectionEnd', txt.length);\r\n    }\r\n  }\r\n\r\n  togglePopup() {\r\n    if (this.disabled) {\r\n      return;\r\n    }\r\n\r\n    this.popup.toggle(this.input.nativeElement, '');\r\n\r\n    setTimeout(() => {\r\n      if (this.popupVisible) {\r\n        this.focusPopup();\r\n      }\r\n    });\r\n  }\r\n\r\n  btnClick(e: any) {\r\n    this.togglePopup();\r\n  }\r\n\r\n  public setValueFromDisplayed() {\r\n    //\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.popup.position = this.currentPopupPosition;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this.popupVisible) {\r\n      this.popup.closePopup();\r\n    }\r\n  }\r\n\r\n  constructor(\r\n    protected _elementRef: ElementRef,\r\n    protected _renderer: Renderer2) { }\r\n}\r\n"]}