UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

307 lines 32 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. */ 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"]}