UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

135 lines 17.3 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, ChangeDetectorRef } from '@angular/core'; import { Keys } from '@true-directive/base'; import { DOMUtils } from '../common/dom-utils.class'; // showPopupRelative - устанавливаем position: relative для popup container // Если этого не сделать, то popup-element будет увеличивать data area. // Вообще этот параметр сделает невозможным редактирование даты в // абсолютно позиционированных контейнерах (модальные окна, например). var EditorDateComponent = /** @class */ (function () { function EditorDateComponent(changeDetector) { this.changeDetector = changeDetector; this.value = null; this.datepickerInputClass = 'true-grid-input'; this.commit = new EventEmitter(); this.cancel = new EventEmitter(); this.change = new EventEmitter(); this._initialized = false; } EditorDateComponent.prototype.init = function (value, valueChanged, height, ie, wasShown) { if (ie === void 0) { ie = false; } if (wasShown === void 0) { wasShown = false; } if (this.state.touchMode) { this.datepicker.popupPosition = 'MODAL'; } else { this.datepicker.popupPosition = 'RELATIVE'; } this.ie = ie; this.valueTemp = value; this.valueChanged = valueChanged; this.height = height; if (this.state.iOS) { DOMUtils.focusAndOpenKeyboard(this.datepicker.input.nativeElement, 50); } }; EditorDateComponent.prototype.ngAfterContentInit = function () { var _this = this; if (!this.valueChanged) { this.value = this.valueTemp; setTimeout(function () { return _this.datepicker.focus(); }); this._initialized = true; } else { this.datepicker.focus(); var txt_1 = this.valueTemp; setTimeout(function () { for (var i = 0; i < txt_1.length; i++) { var e = Keys.generateEvent(null, 0, txt_1[i]); _this.datepicker.acceptKey(e); } _this._initialized = true; }); } // Не помогает // setTimeout(() => this.changeDetector.detectChanges(), 100); }; EditorDateComponent.prototype.datepickerChange = function (e) { if (this._initialized) { this.change.emit(this.purify(e)); } }; EditorDateComponent.prototype.inputMouseDown = function (e) { e.stopPropagation(); }; EditorDateComponent.prototype.inputKeyDown = function (e) { if (e.keyCode === Keys.UP || e.keyCode === Keys.DOWN || e.keyCode === Keys.TAB) { return; } if (e.keyCode === Keys.ESCAPE) { this.cancel.emit(false); return; } e.stopPropagation(); if (e.keyCode === Keys.ENTER) { this.commit.emit(this.purify(this.value)); return; } }; EditorDateComponent.prototype.getClass = function () { var res = 'true-editor-date__datepicker'; if (this.height !== null && this.height > 0) { return res; } if (this.ie) { return res + ' true-grid-editor-ie'; } else { return res + ' true-grid-editor-100p'; } }; EditorDateComponent.prototype.getH = function () { if (this.height !== null && this.height > 0) { return this.height + 'px'; } return '100%'; }; EditorDateComponent.prototype.purify = function (v) { if (v === undefined || v === null || isNaN(v.getTime())) { return null; } return v; }; tslib_1.__decorate([ ViewChild('datepicker', { static: true }), tslib_1.__metadata("design:type", Object) ], EditorDateComponent.prototype, "datepicker", void 0); tslib_1.__decorate([ Output("commit"), tslib_1.__metadata("design:type", EventEmitter) ], EditorDateComponent.prototype, "commit", void 0); tslib_1.__decorate([ Output("cancel"), tslib_1.__metadata("design:type", EventEmitter) ], EditorDateComponent.prototype, "cancel", void 0); tslib_1.__decorate([ Output("change"), tslib_1.__metadata("design:type", EventEmitter) ], EditorDateComponent.prototype, "change", void 0); EditorDateComponent = tslib_1.__decorate([ Component({ selector: 'true-editor-date', template: "<div class=\"true-grid__input-container\" [style.height]=\"getH()\">\n <true-datepicker #datepicker\n class=\"true-editor-date__datepicker\"\n [pattern]=\"column.format\"\n [ngClass]=\"getClass()\"\n [inputClass]=\"datepickerInputClass\"\n [showError]=\"false\"\n [(ngModel)]=\"value\"\n (keydown)=\"inputKeyDown($event)\"\n (ngModelChange)=\"datepickerChange($event)\">\n </true-datepicker>\n </div>", styles: ["\n :host {\n padding: 0;\n margin: 0;\n border: 0;\n }\n .true-editor-date__datepicker {\n width: 100%;\n height: 100%;\n padding: 0;\n margin: 0;\n }\n "] }), tslib_1.__metadata("design:paramtypes", [ChangeDetectorRef]) ], EditorDateComponent); return EditorDateComponent; }()); export { EditorDateComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor-date.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/editors/editor-date.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, Output, EventEmitter, ViewChild, ChangeDetectorRef } from '@angular/core';\r\n\r\nimport { Column } from '@true-directive/base';\r\nimport { GridStateService } from '../grid-state.service';\r\nimport { Keys } from '@true-directive/base';\r\nimport { DOMUtils } from '../common/dom-utils.class';\r\n\r\nimport { IEditor } from \"./editor.interface\";\r\n\r\n// showPopupRelative - устанавливаем position: relative для popup container\r\n// Если этого не сделать, то popup-element будет увеличивать data area.\r\n// Вообще этот параметр сделает невозможным редактирование даты в\r\n// абсолютно позиционированных контейнерах (модальные окна, например).\r\n@Component({\r\n  selector: 'true-editor-date',\r\n  template:\r\n  `<div class=\"true-grid__input-container\" [style.height]=\"getH()\">\r\n    <true-datepicker #datepicker\r\n      class=\"true-editor-date__datepicker\"\r\n      [pattern]=\"column.format\"\r\n      [ngClass]=\"getClass()\"\r\n      [inputClass]=\"datepickerInputClass\"\r\n      [showError]=\"false\"\r\n      [(ngModel)]=\"value\"\r\n      (keydown)=\"inputKeyDown($event)\"\r\n      (ngModelChange)=\"datepickerChange($event)\">\r\n    </true-datepicker>\r\n  </div>`,\r\n  styles: [`\r\n    :host {\r\n      padding: 0;\r\n      margin: 0;\r\n      border: 0;\r\n    }\r\n    .true-editor-date__datepicker {\r\n      width: 100%;\r\n      height: 100%;\r\n      padding: 0;\r\n      margin: 0;\r\n    }\r\n    `]\r\n  })\r\nexport class EditorDateComponent implements IEditor  {\r\n\r\n  ie: boolean;\r\n  value: any = null;\r\n  valueTemp: any;\r\n  valueChanged: boolean;\r\n  height: number;\r\n\r\n  datepickerInputClass = 'true-grid-input';\r\n\r\n  @ViewChild('datepicker', {static: true})\r\n  datepicker: any;\r\n\r\n  // Implementation of IEditor\r\n  state: GridStateService;\r\n  column: Column;\r\n  row: any;\r\n\r\n  @Output(\"commit\")\r\n  commit: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output(\"cancel\")\r\n  cancel: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output(\"change\")\r\n  change: EventEmitter<any> = new EventEmitter();\r\n\r\n  private _initialized = false;\r\n  init(value: any, valueChanged: boolean, height: number, ie: boolean = false, wasShown: boolean = false) {\r\n\r\n    if (this.state.touchMode) {\r\n      this.datepicker.popupPosition = 'MODAL';\r\n    } else {\r\n      this.datepicker.popupPosition = 'RELATIVE';\r\n    }\r\n\r\n    this.ie = ie;\r\n    this.valueTemp = value;\r\n    this.valueChanged = valueChanged;\r\n    this.height = height;\r\n\r\n    if (this.state.iOS) {\r\n      DOMUtils.focusAndOpenKeyboard(this.datepicker.input.nativeElement, 50);\r\n    }\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    if(!this.valueChanged) {\r\n      this.value = this.valueTemp;\r\n      setTimeout(() => this.datepicker.focus());\r\n      this._initialized = true;\r\n    } else {\r\n      this.datepicker.focus();\r\n      const txt = this.valueTemp;\r\n      setTimeout(() => {\r\n        for (let i = 0; i < txt.length; i++) {\r\n          const e = Keys.generateEvent(null, 0, txt[i]);\r\n          this.datepicker.acceptKey(e);\r\n        }\r\n        this._initialized = true;\r\n      });\r\n    }\r\n\r\n    // Не помогает\r\n    // setTimeout(() => this.changeDetector.detectChanges(), 100);\r\n  }\r\n\r\n  datepickerChange(e: any) {\r\n    if (this._initialized) {\r\n      this.change.emit(this.purify(e));\r\n    }\r\n  }\r\n\r\n  inputMouseDown(e: any) {\r\n    e.stopPropagation();\r\n  }\r\n\r\n  inputKeyDown(e: any) {\r\n\r\n    if (e.keyCode === Keys.UP || e.keyCode === Keys.DOWN || e.keyCode === Keys.TAB) {\r\n      return;\r\n    }\r\n\r\n    if (e.keyCode === Keys.ESCAPE) {\r\n      this.cancel.emit(false);\r\n      return;\r\n    }\r\n\r\n    e.stopPropagation();\r\n\r\n    if (e.keyCode === Keys.ENTER) {\r\n      this.commit.emit(this.purify(this.value));\r\n      return;\r\n    }\r\n  }\r\n\r\n  getClass() {\r\n    let res = 'true-editor-date__datepicker';\r\n    if (this.height !== null && this.height > 0) {\r\n      return res;\r\n    }\r\n\r\n    if (this.ie) {\r\n      return res + ' true-grid-editor-ie';\r\n    } else {\r\n      return res + ' 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  protected purify(v: any): any {\r\n    if (v === undefined || v === null || isNaN(v.getTime())) {\r\n      return null;\r\n    }\r\n    return v;\r\n  }\r\n\r\n  constructor(private changeDetector: ChangeDetectorRef) { }\r\n}\r\n"]}