@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
144 lines • 17.2 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, Renderer2 } from '@angular/core';
import { Keys } from '@true-directive/base';
import { MaskNumberDirective } from '../mask/mask-number.directive';
var EditorNumberComponent = /** @class */ (function () {
function EditorNumberComponent(_renderer) {
this._renderer = _renderer;
this.ie = false;
this.value = null;
this.format = '{1.2}';
this.height = 0;
this.commit = new EventEmitter();
this.cancel = new EventEmitter();
this.change = new EventEmitter();
this._initialized = false;
}
EditorNumberComponent.prototype.init = function (value, valueChanged, height, ie, wasShown) {
if (ie === void 0) { ie = false; }
if (wasShown === void 0) { wasShown = false; }
this.ie = ie;
this.valueChanged = valueChanged;
this.valueTemp = value;
this.height = height;
};
EditorNumberComponent.prototype.ngAfterContentInit = function () {
var _this = this;
if (!this.valueChanged) {
this.value = this.valueTemp;
setTimeout(function () { return _this.input.nativeElement.select(); });
this._initialized = true;
}
else {
var txt_1 = this.valueTemp;
setTimeout(function () {
if (txt_1 !== null && txt_1 !== '') {
for (var i = 0; i < txt_1.length; i++) {
var e = Keys.generateEvent(_this.input.nativeElement, 99, txt_1[i]);
_this.maskNumberDirective.processKey(e);
}
_this._initialized = true;
_this.inputChange(txt_1);
}
_this.input.nativeElement.focus();
});
}
};
EditorNumberComponent.prototype.inputMouseDown = function (e) {
e.stopPropagation();
};
EditorNumberComponent.prototype.inputChange = function (e) {
if (!this._initialized) {
return;
}
//Только если valid number. Иначе нулл
if (isNaN(e) || e === '' || e === null) {
this.change.emit(null);
return;
}
this.change.emit(+e);
};
EditorNumberComponent.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;
}
};
// Если у нас есть информация о высоте строки - берем её и не
// назначаем никакого класса
EditorNumberComponent.prototype.getClass = function () {
if ((this.height !== null && this.height > 0)) {
return '';
}
if (this.ie) {
return 'true-grid-editor-ie';
}
else {
return 'true-grid-editor-100p';
}
};
EditorNumberComponent.prototype.getH = function () {
if (this.height !== null && this.height > 0) {
return this.height + 'px';
}
return '100%';
};
EditorNumberComponent.prototype.getFormat = function () {
if (this.column.format !== '') {
return this.column.format;
}
return '{1}';
};
tslib_1.__decorate([
ViewChild('input', { static: true }),
tslib_1.__metadata("design:type", Object)
], EditorNumberComponent.prototype, "input", void 0);
tslib_1.__decorate([
ViewChild('input', { read: MaskNumberDirective, static: true }),
tslib_1.__metadata("design:type", MaskNumberDirective)
], EditorNumberComponent.prototype, "maskNumberDirective", void 0);
tslib_1.__decorate([
Output('commit'),
tslib_1.__metadata("design:type", EventEmitter)
], EditorNumberComponent.prototype, "commit", void 0);
tslib_1.__decorate([
Output('cancel'),
tslib_1.__metadata("design:type", EventEmitter)
], EditorNumberComponent.prototype, "cancel", void 0);
tslib_1.__decorate([
Output('change'),
tslib_1.__metadata("design:type", EventEmitter)
], EditorNumberComponent.prototype, "change", void 0);
EditorNumberComponent = tslib_1.__decorate([
Component({
selector: 'true-editor-number',
template: "<input #input\n class=\"true-grid-input true-editor-number__input true-grid__input-container\"\n [true-mask-number]=\"getFormat()\"\n [style.height]=\"getH()\"\n [ngClass]=\"getClass()\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"inputChange($event)\"\n (mousedown)=\"inputMouseDown($event)\"\n (keydown)=\"inputKeyDown($event)\" />",
styles: ["\n :host {\n padding: 0;\n }\n .true-editor-number__input {\n text-align: right;\n }\n "]
}),
tslib_1.__metadata("design:paramtypes", [Renderer2])
], EditorNumberComponent);
return EditorNumberComponent;
}());
export { EditorNumberComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor-number.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/editors/editor-number.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, Renderer2 } 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\n\r\nimport { MaskNumberDirective } from '../mask/mask-number.directive';\r\n\r\nimport { IEditor } from \"./editor.interface\";\r\n\r\n@Component({\r\n  selector: 'true-editor-number',\r\n  template: `<input #input\r\n              class=\"true-grid-input true-editor-number__input true-grid__input-container\"\r\n              [true-mask-number]=\"getFormat()\"\r\n              [style.height]=\"getH()\"\r\n              [ngClass]=\"getClass()\"\r\n              [(ngModel)]=\"value\"\r\n              (ngModelChange)=\"inputChange($event)\"\r\n              (mousedown)=\"inputMouseDown($event)\"\r\n              (keydown)=\"inputKeyDown($event)\" />`,\r\n  styles: [`\r\n    :host {\r\n      padding: 0;\r\n    }\r\n    .true-editor-number__input {\r\n      text-align: right;\r\n    }\r\n    `]\r\n  })\r\nexport class EditorNumberComponent implements IEditor {\r\n\r\n  ie = false;\r\n  value: number | null = null;\r\n  valueTemp: any;\r\n  valueChanged: boolean;\r\n  format = '{1.2}';\r\n  height = 0;\r\n\r\n  @ViewChild('input', {static: true})\r\n  input: any;\r\n\r\n  @ViewChild('input', {read: MaskNumberDirective, static: true})\r\n  maskNumberDirective: MaskNumberDirective;\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<void> = 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    this.ie = ie;\r\n    this.valueChanged = valueChanged;\r\n    this.valueTemp = value;\r\n    this.height = height;\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    if(!this.valueChanged) {\r\n      this.value = this.valueTemp;\r\n      setTimeout(() => this.input.nativeElement.select());\r\n      this._initialized = true;\r\n    } else {\r\n      const txt = this.valueTemp;\r\n      setTimeout(() => {\r\n        if (txt !== null && txt !== '') {\r\n          for (let i = 0; i < txt.length; i++) {\r\n            const e = Keys.generateEvent(this.input.nativeElement, 99, txt[i]);\r\n            this.maskNumberDirective.processKey(e);\r\n          }\r\n          this._initialized = true;\r\n          this.inputChange(txt);\r\n        }\r\n        this.input.nativeElement.focus();\r\n      });\r\n    }\r\n  }\r\n\r\n  inputMouseDown(e: any) {\r\n    e.stopPropagation();\r\n  }\r\n\r\n  inputChange(e: any) {\r\n\r\n    if (!this._initialized) {\r\n      return;\r\n    }\r\n\r\n    //Только если valid number. Иначе нулл\r\n    if (isNaN(e) || e === '' || e === null) {\r\n      this.change.emit(null);\r\n      return;\r\n    }\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  // Если у нас есть информация о высоте строки - берем её и не\r\n  // назначаем никакого класса\r\n  getClass() {\r\n\r\n    if ((this.height !== null && this.height > 0)) {\r\n      return '';\r\n    }\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  getFormat() {\r\n    if (this.column.format !== '') {\r\n      return this.column.format;\r\n    }\r\n    return '{1}';\r\n  }\r\n\r\n  constructor(protected _renderer: Renderer2) { }\r\n}\r\n"]}