@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
227 lines • 28.4 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, Output, EventEmitter, ViewChild, ElementRef, Renderer2 } from '@angular/core';
import { Keys } from '@true-directive/base';
import { Utils } from '@true-directive/base';
import { CalendarComponent } from '../controls/calendar.component';
import { PopupComponent } from '../controls/popup.component';
import { MaskDateDirective } from '../mask/mask-date.directive';
import { DOMUtils } from '../common/dom-utils.class';
var EditorTestComponent = /** @class */ (function () {
function EditorTestComponent(_renderer, _elementRef) {
this._renderer = _renderer;
this._elementRef = _elementRef;
this.ie = false;
this.valueTemp = false;
this.valueChanged = false;
this.height = 0;
this.datepickerInputClass = 'true-grid-input';
this._initialized = false;
this.commit = new EventEmitter();
this.change = new EventEmitter();
this.cancel = new EventEmitter();
}
Object.defineProperty(EditorTestComponent.prototype, "popupVisible", {
get: function () {
return this.popup.visible;
},
enumerable: true,
configurable: true
});
EditorTestComponent.prototype.getIcon = function () {
return 'true-icon-calendar-empty';
};
EditorTestComponent.prototype.datepickerChange = function (e) {
if (this._initialized) {
this.change.emit(this.purify(e));
}
};
EditorTestComponent.prototype.dateClick = function (e) {
this.inputChange(e);
this.popup.closePopup();
};
EditorTestComponent.prototype.togglePopup = function () {
var _this = this;
this.popup.toggle(this._elementRef.nativeElement, '');
setTimeout(function () {
if (_this.popupVisible) {
_this.focusPopup();
}
});
};
EditorTestComponent.prototype.btnClick = function (e) {
this.togglePopup();
};
EditorTestComponent.prototype.popupClose = function (e) {
var _this = this;
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._renderer) {
_this._renderer.setProperty(_this.input.nativeElement, 'selectionStart', 0);
_this._renderer.setProperty(_this.input.nativeElement, 'selectionEnd', txt.length);
}
});
}
};
EditorTestComponent.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.popup.position = 'MODAL';
}
else {
this.popup.position = 'RELATIVE';
}
this.valueTemp = value;
this.valueChanged = valueChanged;
this.height = height;
this.ie = ie;
if (this.state.iOS) {
DOMUtils.focusAndOpenKeyboard(this.input.nativeElement, 50);
}
};
// Останавливаем propagation, чтобы не влиять на grid
EditorTestComponent.prototype.inputMouseDown = function (e) {
e.stopPropagation();
};
EditorTestComponent.prototype.inputChange = function (e) {
this.change.emit(e);
};
EditorTestComponent.prototype.inputKeyDown = function (e) {
if (e.defaultPrevented) {
return;
}
if (e.keyCode === Keys.DOWN && e.altKey && !this.popup.visible) {
this.togglePopup();
e.preventDefault();
e.stopPropagation();
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;
}
};
EditorTestComponent.prototype.escape = function (e) {
this.popup.closePopup();
};
EditorTestComponent.prototype.acceptKey = function (e) {
this.maskDateDirective.keyDown(Keys.generateEvent(this.input.nativeElement, -1, Keys.keyChar(e), e.shiftKey, e.ctrlKey));
};
EditorTestComponent.prototype.ngAfterContentInit = function () {
var _this = this;
if (!this.valueChanged) {
this.value = this.valueTemp;
// The pattern hasn't applied yet.
this.maskDateDirective.pattern = this.column.format;
this.maskDateDirective.writeValue(this.value);
setTimeout(function () {
if (!_this.state.touchMode) {
// Select all if not mobile device
_this.input.nativeElement.select();
}
_this.input.nativeElement.focus();
});
this._initialized = true;
}
else {
this.input.nativeElement.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.acceptKey(e);
}
_this._initialized = true;
});
}
};
EditorTestComponent.prototype.focusPopup = function () {
this.calendar.setFocus();
};
// Если у нас есть информация о высоте строки - берем её и не
// назначаем никакого класса
EditorTestComponent.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';
}
};
EditorTestComponent.prototype.getH = function () {
if (this.height !== null && this.height > 0) {
return this.height + 'px';
}
return '100%';
};
EditorTestComponent.prototype.purify = function (v) {
if (v === undefined || v === null || isNaN(v.getTime())) {
return null;
}
return v;
};
tslib_1.__decorate([
ViewChild('popup', { static: true }),
tslib_1.__metadata("design:type", PopupComponent)
], EditorTestComponent.prototype, "popup", void 0);
tslib_1.__decorate([
ViewChild('input', { static: true }),
tslib_1.__metadata("design:type", Object)
], EditorTestComponent.prototype, "input", void 0);
tslib_1.__decorate([
ViewChild('calendar', { static: true }),
tslib_1.__metadata("design:type", CalendarComponent)
], EditorTestComponent.prototype, "calendar", void 0);
tslib_1.__decorate([
ViewChild('input', { read: MaskDateDirective, static: true }),
tslib_1.__metadata("design:type", MaskDateDirective)
], EditorTestComponent.prototype, "maskDateDirective", void 0);
tslib_1.__decorate([
Output("commit"),
tslib_1.__metadata("design:type", EventEmitter)
], EditorTestComponent.prototype, "commit", void 0);
tslib_1.__decorate([
Output("change"),
tslib_1.__metadata("design:type", EventEmitter)
], EditorTestComponent.prototype, "change", void 0);
tslib_1.__decorate([
Output("cancel"),
tslib_1.__metadata("design:type", EventEmitter)
], EditorTestComponent.prototype, "cancel", void 0);
EditorTestComponent = tslib_1.__decorate([
Component({
selector: 'true-editor-test',
template: "<true-input-wrapper\n class=\"true-datepicker__input\"\n (btnClick)=\"btnClick($event)\"\n [ngClass]=\"getClass()\"\n [style.height]=\"getH()\"\n [icon]=\"getIcon()\"><input #input\n class=\"true-grid-input\"\n [true-mask-date]=\"column.format\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"inputChange($event)\"\n [style.height]=\"getH()\"\n (mousedown)=\"inputMouseDown($event)\"\n (keydown)=\"inputKeyDown($event)\" /></true-input-wrapper><true-popup #popup (close)=\"popupClose($event)\">\n <true-calendar #calendar\n *ngIf=\"popupVisible\"\n [(ngModel)]=\"value\"\n (escape)=\"escape($event)\"\n (dateClick)=\"dateClick($event)\">\n </true-calendar>\n </true-popup>",
styles: ["\n :host {\n padding: 0;\n }\n .true-datepicker__input {\n border: 0;\n }\n "]
}),
tslib_1.__metadata("design:paramtypes", [Renderer2,
ElementRef])
], EditorTestComponent);
return EditorTestComponent;
}());
export { EditorTestComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor-test.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/editors/editor-test.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, ElementRef,\r\n         Renderer2 } from '@angular/core';\r\n\r\nimport { Column } from '@true-directive/base';\r\nimport { Keys } from '@true-directive/base';\r\nimport { Utils } from '@true-directive/base';\r\n\r\nimport { CalendarComponent } from '../controls/calendar.component';\r\nimport { PopupComponent } from '../controls/popup.component';\r\nimport { MaskDateDirective } from  '../mask/mask-date.directive';\r\n\r\nimport { GridStateService } from '../grid-state.service';\r\nimport { IEditor } from \"./editor.interface\";\r\nimport { DOMUtils } from '../common/dom-utils.class';\r\n\r\n@Component({\r\n  selector: 'true-editor-test',\r\n  template: `<true-input-wrapper\r\n    class=\"true-datepicker__input\"\r\n    (btnClick)=\"btnClick($event)\"\r\n    [ngClass]=\"getClass()\"\r\n    [style.height]=\"getH()\"\r\n    [icon]=\"getIcon()\"><input #input\r\n                  class=\"true-grid-input\"\r\n                  [true-mask-date]=\"column.format\"\r\n                  [(ngModel)]=\"value\"\r\n                  (ngModelChange)=\"inputChange($event)\"\r\n                  [style.height]=\"getH()\"\r\n                  (mousedown)=\"inputMouseDown($event)\"\r\n                  (keydown)=\"inputKeyDown($event)\" /></true-input-wrapper><true-popup #popup (close)=\"popupClose($event)\">\r\n                    <true-calendar #calendar\r\n                        *ngIf=\"popupVisible\"\r\n                        [(ngModel)]=\"value\"\r\n                        (escape)=\"escape($event)\"\r\n                        (dateClick)=\"dateClick($event)\">\r\n                    </true-calendar>\r\n                  </true-popup>`,\r\n  styles: [`\r\n    :host {\r\n      padding: 0;\r\n    }\r\n    .true-datepicker__input {\r\n      border: 0;\r\n    }\r\n    `]\r\n  })\r\nexport class EditorTestComponent implements IEditor {\r\n\r\n  private ie: boolean = false;\r\n  private valueTemp: any = false;\r\n  private valueChanged: boolean = false;\r\n  private height: number = 0;\r\n\r\n  public value: any;\r\n  datepickerInputClass = 'true-grid-input';\r\n\r\n  state: GridStateService;\r\n  column: Column;\r\n  row: any;\r\n\r\n  private _initialized = false;\r\n\r\n  @ViewChild('popup', {static: true})\r\n  popup: PopupComponent;\r\n\r\n  @ViewChild('input', {static: true})\r\n  input: any;\r\n\r\n  @ViewChild('calendar', {static: true})\r\n  calendar: CalendarComponent;\r\n\r\n  @ViewChild('input', {read: MaskDateDirective, static: true})\r\n  maskDateDirective: MaskDateDirective;\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  get popupVisible() {\r\n    return this.popup.visible;\r\n  }\r\n\r\n  getIcon(): string {\r\n    return 'true-icon-calendar-empty';\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  dateClick(e: any) {\r\n    this.inputChange(e);\r\n    this.popup.closePopup();\r\n  }\r\n\r\n  togglePopup() {\r\n    this.popup.toggle(this._elementRef.nativeElement, '');\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  popupClose(e: any) {\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._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  init(value: any, valueChanged: boolean, height: number, ie: boolean = false, wasShown: boolean = false) {\r\n\r\n    if (this.state.touchMode) {\r\n      this.popup.position = 'MODAL';\r\n    } else {\r\n      this.popup.position = 'RELATIVE';\r\n    }\r\n\r\n    this.valueTemp = 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.DOWN && e.altKey && !this.popup.visible) {\r\n      this.togglePopup();\r\n      e.preventDefault();\r\n      e.stopPropagation();\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  escape(e: any) {\r\n    this.popup.closePopup();\r\n  }\r\n\r\n  acceptKey(e: any) {\r\n    this.maskDateDirective.keyDown(\r\n      Keys.generateEvent(this.input.nativeElement, -1, Keys.keyChar(e), e.shiftKey, e.ctrlKey)\r\n    );\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n\r\n    if(!this.valueChanged) {\r\n      this.value = this.valueTemp;\r\n      // The pattern hasn't applied yet.\r\n      this.maskDateDirective.pattern = this.column.format;\r\n      this.maskDateDirective.writeValue(this.value);\r\n      setTimeout(() => {\r\n        if (!this.state.touchMode) {\r\n          // Select all if not mobile device\r\n          this.input.nativeElement.select()\r\n        }\r\n        this.input.nativeElement.focus();\r\n      });\r\n      this._initialized = true;\r\n    } else {\r\n      this.input.nativeElement.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.acceptKey(e);\r\n        }\r\n        this._initialized = true;\r\n      });\r\n    }\r\n  }\r\n\r\n  focusPopup() {\r\n    this.calendar.setFocus();\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  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(protected _renderer: Renderer2,\r\n              protected _elementRef: ElementRef) { }\r\n}\r\n"]}