UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

126 lines 15.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, Output, EventEmitter, ViewChild, Renderer2 } from '@angular/core'; import { Keys } from '@true-directive/base'; import { DOMUtils } from '../common/dom-utils.class'; var EditorTextComponent = /** @class */ (function () { function EditorTextComponent(_renderer) { this._renderer = _renderer; this.ie = false; this.valueChanged = false; this.height = 0; this.commit = new EventEmitter(); this.change = new EventEmitter(); this.cancel = new EventEmitter(); } EditorTextComponent.prototype.init = function (value, valueChanged, height, ie, wasShown) { if (ie === void 0) { ie = false; } if (wasShown === void 0) { wasShown = false; } this.value = value; this.valueChanged = valueChanged; this.height = height; this.ie = ie; if (this.state.iOS) { DOMUtils.focusAndOpenKeyboard(this.input.nativeElement, 50); } }; // Останавливаем propagation, чтобы не влиять на grid EditorTextComponent.prototype.inputMouseDown = function (e) { e.stopPropagation(); }; EditorTextComponent.prototype.inputChange = function (e) { this.change.emit(e); }; EditorTextComponent.prototype.inputKeyDown = function (e) { if (e.defaultPrevented) { return; } if (e.keyCode === Keys.UP || e.keyCode === Keys.DOWN || e.keyCode === Keys.PAGE_UP || e.keyCode === Keys.PAGE_DOWN || e.keyCode === Keys.TAB) { // По идее просто их должен отработать грид return; } e.stopPropagation(); if (e.keyCode === Keys.ESCAPE) { this.cancel.emit(); return; } if (e.keyCode === Keys.ENTER) { this.commit.emit(this.value); return; } }; EditorTextComponent.prototype.ngAfterContentInit = function () { var _this = this; if (!this.valueChanged) { if (this.state.iOS) { // Мы уже позаботились об этом при инициализации } else { setTimeout(function () { _this.input.nativeElement.select(); _this.input.nativeElement.focus(); }); } } else { this.input.nativeElement.focus(); this._renderer.setProperty(this.input.nativeElement, 'value', this.value); this._renderer.setProperty(this.input.nativeElement, 'selectionStart', this.value.length); this._renderer.setProperty(this.input.nativeElement, 'selectionEnd', this.value.length); } }; // Если у нас есть информация о высоте строки - берем её и не // назначаем никакого класса EditorTextComponent.prototype.getClass = function () { if ((this.height !== null && this.height > 0)) { return 'true-grid__input-container'; } if (this.ie) { return 'true-grid-editor-ie'; } else { return 'true-grid-editor-100p'; } }; EditorTextComponent.prototype.getH = function () { if (this.height !== null && this.height > 0) { return this.height + 'px'; } return '100%'; }; tslib_1.__decorate([ ViewChild('input', { static: true }), tslib_1.__metadata("design:type", Object) ], EditorTextComponent.prototype, "input", void 0); tslib_1.__decorate([ Output("commit"), tslib_1.__metadata("design:type", EventEmitter) ], EditorTextComponent.prototype, "commit", void 0); tslib_1.__decorate([ Output("change"), tslib_1.__metadata("design:type", EventEmitter) ], EditorTextComponent.prototype, "change", void 0); tslib_1.__decorate([ Output("cancel"), tslib_1.__metadata("design:type", EventEmitter) ], EditorTextComponent.prototype, "cancel", void 0); EditorTextComponent = tslib_1.__decorate([ Component({ selector: 'true-editor-text', template: "<input #input class=\"true-grid-input\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"inputChange($event)\"\n [style.height]=\"getH()\"\n [ngClass]=\"getClass()\"\n (mousedown)=\"inputMouseDown($event)\"\n (keydown)=\"inputKeyDown($event)\" />", styles: ["\n :host {\n padding: 0;\n }\n "] }), tslib_1.__metadata("design:paramtypes", [Renderer2]) ], EditorTextComponent); return EditorTextComponent; }()); export { EditorTextComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor-text.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/editors/editor-text.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, ViewChild,\r\n         Renderer2 } from '@angular/core';\r\n\r\nimport { Column } from '@true-directive/base';\r\nimport { Keys } from '@true-directive/base';\r\n\r\nimport { GridStateService } from '../grid-state.service';\r\nimport { IEditor } from \"./editor.interface\";\r\n\r\nimport { DOMUtils } from '../common/dom-utils.class';\r\n\r\n@Component({\r\n  selector: 'true-editor-text',\r\n  template: `<input #input class=\"true-grid-input\"\r\n                  [(ngModel)]=\"value\"\r\n                  (ngModelChange)=\"inputChange($event)\"\r\n                  [style.height]=\"getH()\"\r\n                  [ngClass]=\"getClass()\"\r\n                  (mousedown)=\"inputMouseDown($event)\"\r\n                  (keydown)=\"inputKeyDown($event)\" />`,\r\n  styles: [`\r\n    :host {\r\n      padding: 0;\r\n    }\r\n    `]\r\n  })\r\nexport class EditorTextComponent implements IEditor {\r\n\r\n  private ie: boolean = false;\r\n  private valueChanged: boolean = false;\r\n  private height: number = 0;\r\n\r\n  public value: string;\r\n\r\n  state: GridStateService;\r\n  column: Column;\r\n  row: any;\r\n\r\n  @ViewChild('input', {static: true})\r\n  input: any;\r\n\r\n  @Output(\"commit\")\r\n  commit: EventEmitter<string> = new EventEmitter();\r\n\r\n  @Output(\"change\")\r\n  change: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output(\"cancel\")\r\n  cancel: EventEmitter<void> = new EventEmitter();\r\n\r\n  init(value: any, valueChanged: boolean, height: number, ie: boolean = false, wasShown: boolean = false) {\r\n    this.value = value;\r\n    this.valueChanged = valueChanged;\r\n    this.height = height;\r\n    this.ie = ie;\r\n    if (this.state.iOS) {\r\n      DOMUtils.focusAndOpenKeyboard(this.input.nativeElement, 50);\r\n    }\r\n  }\r\n\r\n  // Останавливаем propagation, чтобы не влиять на grid\r\n  inputMouseDown(e: any) {\r\n    e.stopPropagation();\r\n  }\r\n\r\n  inputChange(e: any) {\r\n    this.change.emit(e);\r\n  }\r\n\r\n  inputKeyDown(e: any) {\r\n\r\n    if (e.defaultPrevented) {\r\n      return;\r\n    }\r\n\r\n    if (e.keyCode === Keys.UP ||\r\n        e.keyCode === Keys.DOWN ||\r\n        e.keyCode === Keys.PAGE_UP ||\r\n        e.keyCode === Keys.PAGE_DOWN ||\r\n        e.keyCode === Keys.TAB) {\r\n      // По идее просто их должен отработать грид\r\n      return;\r\n    }\r\n\r\n    e.stopPropagation();\r\n\r\n    if (e.keyCode === Keys.ESCAPE) {\r\n      this.cancel.emit();\r\n      return;\r\n    }\r\n\r\n    if (e.keyCode === Keys.ENTER) {\r\n      this.commit.emit(this.value);\r\n      return;\r\n    }\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    if(!this.valueChanged) {\r\n      if (this.state.iOS) {\r\n        // Мы уже позаботились об этом при инициализации\r\n      } else {\r\n        setTimeout(() => {\r\n          this.input.nativeElement.select()\r\n          this.input.nativeElement.focus();\r\n        });\r\n      }\r\n    } else {\r\n      this.input.nativeElement.focus();\r\n      this._renderer.setProperty(this.input.nativeElement, 'value', this.value);\r\n      this._renderer.setProperty(this.input.nativeElement, 'selectionStart', this.value.length);\r\n      this._renderer.setProperty(this.input.nativeElement, 'selectionEnd', this.value.length);\r\n    }\r\n  }\r\n\r\n  // Если у нас есть информация о высоте строки - берем её и не\r\n  // назначаем никакого класса\r\n  getClass() {\r\n    if ((this.height !== null && this.height > 0)) {\r\n      return 'true-grid__input-container';\r\n    }\r\n    if (this.ie) {\r\n      return 'true-grid-editor-ie';\r\n    } else {\r\n      return 'true-grid-editor-100p';\r\n    }\r\n  }\r\n\r\n  getH() {\r\n    if (this.height !== null && this.height > 0) {\r\n      return this.height + 'px';\r\n    }\r\n    return '100%';\r\n  }\r\n\r\n  constructor(protected _renderer: Renderer2) { }\r\n}\r\n"]}