@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
307 lines • 32 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 } from '@angular/core';
import { PopupComponent } from './popup.component';
import { Keys, Utils } from '@true-directive/base';
/**
* Dropdown base component.
*/
var DropdownBaseComponent = /** @class */ (function () {
function DropdownBaseComponent(_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 = function (_) { };
this.onTouched = function () { };
this._validBlur = false;
this._useAltDown = true;
this.shownByKey = false;
this._touched = false;
this._skipFocusOnPopupClose = false;
}
Object.defineProperty(DropdownBaseComponent.prototype, "popupPosition", {
get: function () {
return this.popup.position;
},
set: function (pos) {
this.currentPopupPosition = pos;
if (this.popup) {
this.popup.position = pos;
}
},
enumerable: true,
configurable: true
});
DropdownBaseComponent.prototype.registerOnChange = function (fn) { this.onChange = fn; };
DropdownBaseComponent.prototype.registerOnTouched = function (fn) { this.onTouched = fn; };
Object.defineProperty(DropdownBaseComponent.prototype, "useAltDown", {
get: function () {
return this._useAltDown;
},
set: function (v) {
this._useAltDown = v;
},
enumerable: true,
configurable: true
});
DropdownBaseComponent.prototype.fetchData = function (dataQuery, data) {
//
};
DropdownBaseComponent.prototype.inputBlur = function (e) {
// This touch was accepted
this.onTouched();
// We shouldn't close window if the focus is moved to a popup window
var 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);
};
DropdownBaseComponent.prototype.inputClick = function (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();
}
};
DropdownBaseComponent.prototype.inputTouchStart = function (e) {
this._touched = true;
if (this.disableTextEditor) {
e.stopPropagation();
e.preventDefault();
}
};
DropdownBaseComponent.prototype.inputTouchMove = function (e) {
this._touched = false;
};
DropdownBaseComponent.prototype.inputTouchEnd = function (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();
}
};
Object.defineProperty(DropdownBaseComponent.prototype, "value", {
get: function () {
return this._value;
},
set: function (v) {
if (v !== this._value) {
this._value = v;
this.onChange(v);
}
},
enumerable: true,
configurable: true
});
;
// Send the value to input. Formatter: Ctrl --> View
DropdownBaseComponent.prototype.writeValue = function (value) {
if (this.value !== value) {
this.value = value;
}
};
Object.defineProperty(DropdownBaseComponent.prototype, "popupVisible", {
get: function () {
if (this.popup) {
return this.popup.visible;
}
return false;
},
enumerable: true,
configurable: true
});
DropdownBaseComponent.prototype.focusPopup = function () {
//
};
DropdownBaseComponent.prototype.processKey = function (e) {
return false;
};
DropdownBaseComponent.prototype.showByTarget = function () {
if (!this.usePopup) {
return;
}
this.popup.showByTarget(this.input.nativeElement);
};
DropdownBaseComponent.prototype.closePopup = function () {
this.popup.closePopup();
};
/**
* User's input
* @param e Input event
*/
DropdownBaseComponent.prototype.inputInput = function (e) {
if (e === void 0) { e = null; }
//
};
DropdownBaseComponent.prototype.inputKeyDown = function (e) {
var _this = this;
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(function () { return _this.focusPopup(); });
e.preventDefault();
e.stopPropagation();
return;
}
if (!this.processKey(e)) {
this.keydown.emit(e);
}
};
DropdownBaseComponent.prototype.focus = function () {
this.input.nativeElement.focus();
};
DropdownBaseComponent.prototype.popupClose = function (e) {
var _this = this;
// Можем пропустить это мероприятие, если мы закрываем выпадающую панель,
// находясь в контроле
// 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(function () {
var 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);
}
});
}
};
DropdownBaseComponent.prototype.inputFocus = function (e) {
if (this.disableTextEditor) {
this._renderer.setProperty(this.input.nativeElement, 'selectionStart', 0);
this._renderer.setProperty(this.input.nativeElement, 'selectionEnd', 0);
}
else {
var txt = this.input.nativeElement.value;
this._renderer.setProperty(this.input.nativeElement, 'selectionStart', 0);
this._renderer.setProperty(this.input.nativeElement, 'selectionEnd', txt.length);
}
};
DropdownBaseComponent.prototype.togglePopup = function () {
var _this = this;
if (this.disabled) {
return;
}
this.popup.toggle(this.input.nativeElement, '');
setTimeout(function () {
if (_this.popupVisible) {
_this.focusPopup();
}
});
};
DropdownBaseComponent.prototype.btnClick = function (e) {
this.togglePopup();
};
DropdownBaseComponent.prototype.setValueFromDisplayed = function () {
//
};
DropdownBaseComponent.prototype.ngAfterViewInit = function () {
this.popup.position = this.currentPopupPosition;
};
DropdownBaseComponent.prototype.ngOnDestroy = function () {
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);
return 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":"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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, 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"]}