UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

263 lines 31.1 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 { Subject, Observable } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { Column, ColumnType, GridSettings } from '@true-directive/base'; import { Keys } from '@true-directive/base'; import { DropdownBaseComponent } from '../controls/dropdown-base.component'; var EditorSelectTrueComponent = /** @class */ (function () { function EditorSelectTrueComponent(_renderer) { this._renderer = _renderer; this.destroy$ = new Subject(); this.ie = false; this.valueChanged = false; this.height = 0; this.wasShown = false; this.initialized = false; this._value = null; this.displayValue = ''; this.disableTextEditor = false; this.commit = new EventEmitter(); this.change = new EventEmitter(); this.cancel = new EventEmitter(); /** * Список колонок выпадающего списка */ this._columns = null; /** * Настройки грида в выпадающем списке */ this._settings = null; /** * Данные выпадающего списка */ this._items = null; this._valueField = null; this._displayField = null; } Object.defineProperty(EditorSelectTrueComponent.prototype, "value", { get: function () { return this._value; }, set: function (v) { this._value = v; this.change.emit(v); }, enumerable: true, configurable: true }); Object.defineProperty(EditorSelectTrueComponent.prototype, "maxDropDownHeight", { get: function () { return this.state.settings.maxDropDownHeight; }, enumerable: true, configurable: true }); Object.defineProperty(EditorSelectTrueComponent.prototype, "columns", { get: function () { if (this._columns === null) { if (this.column.optionsColumns !== null) { this._columns = this.column.optionsColumns; } else { this._columns = [new Column('name', 'name', 300, ColumnType.STRING)]; } } return this._columns; }, enumerable: true, configurable: true }); Object.defineProperty(EditorSelectTrueComponent.prototype, "settings", { get: function () { if (this._settings === null) { this._settings = GridSettings.minimal(); this._settings.appearance.class = this.state.settings.appearance.class; this._settings.appearance.enableFocusedAppearance = false; this._settings.showHeader = false; this._settings.searchDelay = 100; } return this._settings; }, enumerable: true, configurable: true }); Object.defineProperty(EditorSelectTrueComponent.prototype, "items", { get: function () { var _this = this; if (this._items === null) { if (this.column.optionsData instanceof Observable) { // Подпись var observable = this.column.optionsData; observable.pipe(takeUntil(this.destroy$)).subscribe(function (data) { _this._items = data; }); } else { this._items = this.column.optionsData; } } return this._items; }, enumerable: true, configurable: true }); Object.defineProperty(EditorSelectTrueComponent.prototype, "valueField", { get: function () { if (this._valueField === null) { this._valueField = this.columns[0].fieldName; } return this._valueField; }, enumerable: true, configurable: true }); Object.defineProperty(EditorSelectTrueComponent.prototype, "displayField", { get: function () { if (this._displayField === null) { this._displayField = this.columns[0].fieldName; } return this._displayField; }, enumerable: true, configurable: true }); EditorSelectTrueComponent.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.input.popupPosition = 'MODAL'; this.disableTextEditor = true; } if (valueChanged) { if (!this.disableTextEditor) { this.displayValue = value; this.valueChanged = true; } else { this.valueChanged = false; } this.change.emit(null); } else { // Без события об изменении this._value = value; } this.wasShown = wasShown; this.height = height; this.ie = ie; }; EditorSelectTrueComponent.prototype.inputItemSelect = function (e) { if (this.state.touchMode) { this.commit.emit(this.value); } }; // Останавливаем propagation, чтобы не влиять на grid EditorSelectTrueComponent.prototype.inputMouseDown = function (e) { e.stopPropagation(); }; EditorSelectTrueComponent.prototype.inputKeyDown = function (e) { if (e.defaultPrevented) { return; } if (e.keyCode === Keys.TAB) { this.input.setValueFromDisplayed(); return; } if (e.keyCode === Keys.UP || e.keyCode === Keys.DOWN || e.keyCode === Keys.PAGE_UP || e.keyCode === Keys.PAGE_DOWN) { // По идее просто их должен отработать грид e.stopPropagation(); return; } e.stopPropagation(); if (e.keyCode === Keys.ESCAPE) { this.cancel.emit(); return; } if (e.keyCode === Keys.ENTER) { this.commit.emit(this.value); return; } }; EditorSelectTrueComponent.prototype.ngAfterContentInit = function () { var _this = this; if (!this.valueChanged) { if (this.state.touchMode) { // На тач устройствах не будем фокусироваться на инпуте, // нам достаточно показать форму для выбора в модальном режиме if (!this.wasShown) { setTimeout(function () { return _this.input.showByTarget(); }); } } else { setTimeout(function () { return _this.input.focus(); }); } return; } this.input.focus(); setTimeout(function () { _this._renderer.setProperty(_this.input.input.nativeElement, 'value', _this.displayValue); _this._renderer.setProperty(_this.input.input.nativeElement, 'selectionStart', _this.displayValue.length); _this._renderer.setProperty(_this.input.input.nativeElement, 'selectionEnd', _this.displayValue.length); _this.input.displayValue = _this.displayValue === null ? '' : _this.displayValue; _this.input.inputInput(); }); }; // Если у нас есть информация о высоте строки - берем её и не // назначаем никакого класса EditorSelectTrueComponent.prototype.getClass = function () { if ((this.height !== null && this.height > 0)) { return 'true-grid__input-container'; } if (this.ie) { return 'true-grid-editor-ie'; } return 'true-grid-editor-100p'; }; EditorSelectTrueComponent.prototype.getH = function () { if (this.height !== null && this.height > 0) { return this.height + 'px'; } return '100%'; }; EditorSelectTrueComponent.prototype.ngOnDestroy = function () { // Если нас удаляют... this.destroy$.next(true); this.destroy$.unsubscribe(); }; tslib_1.__decorate([ ViewChild('input', { static: true }), tslib_1.__metadata("design:type", DropdownBaseComponent) ], EditorSelectTrueComponent.prototype, "input", void 0); tslib_1.__decorate([ Output("commit"), tslib_1.__metadata("design:type", EventEmitter) ], EditorSelectTrueComponent.prototype, "commit", void 0); tslib_1.__decorate([ Output("change"), tslib_1.__metadata("design:type", EventEmitter) ], EditorSelectTrueComponent.prototype, "change", void 0); tslib_1.__decorate([ Output("cancel"), tslib_1.__metadata("design:type", EventEmitter) ], EditorSelectTrueComponent.prototype, "cancel", void 0); EditorSelectTrueComponent = tslib_1.__decorate([ Component({ selector: 'true-editor-select-true', template: "<div [ngClass]=\"getClass()\" [style.height]=\"getH()\">\n <true-select #input\n class=\"true-editor-select__selector\"\n [(ngModel)]=\"value\"\n [style.height]=\"getH()\"\n [valueField]=\"valueField\"\n [displayField]=\"displayField\"\n [columns]=\"columns\"\n [settings]=\"settings\"\n [items]=\"items\"\n [useAltDown]=\"true\"\n [maxDropDownHeight]=\"maxDropDownHeight\"\n [disableTextEditor]=\"disableTextEditor\"\n (mousedown)=\"inputMouseDown($event)\"\n (itemSelect)=\"inputItemSelect($event)\"\n (keydown)=\"inputKeyDown($event)\"></true-select>\n </div>", styles: [":host{box-sizing:border-box;padding:0}.true-editor-select__selector{width:100%}.true-editor-select__selector ::ng-deep .true-select__input{height:100%}.true-editor-select__selector ::ng-deep input{border:0}.true-editor-select__container{padding:0;margin:0;background-color:#00f;box-sizing:border-box;height:100%}"] }), tslib_1.__metadata("design:paramtypes", [Renderer2]) ], EditorSelectTrueComponent); return EditorSelectTrueComponent; }()); export { EditorSelectTrueComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor-select-true.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/editors/editor-select-true.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, OnDestroy } from '@angular/core';\r\n\r\nimport { Subject, Observable } from 'rxjs';\r\nimport { takeUntil, take } from 'rxjs/operators';\r\n\r\nimport { Column, ColumnType, GridSettings } from '@true-directive/base';\r\nimport { Keys } from '@true-directive/base';\r\n\r\nimport { GridStateService } from '../grid-state.service';\r\nimport { DropdownBaseComponent } from '../controls/dropdown-base.component';\r\nimport { IEditor } from \"./editor.interface\";\r\n\r\n@Component({\r\n  selector: 'true-editor-select-true',\r\n  template: `<div [ngClass]=\"getClass()\" [style.height]=\"getH()\">\r\n              <true-select #input\r\n                class=\"true-editor-select__selector\"\r\n                [(ngModel)]=\"value\"\r\n                [style.height]=\"getH()\"\r\n                [valueField]=\"valueField\"\r\n                [displayField]=\"displayField\"\r\n                [columns]=\"columns\"\r\n                [settings]=\"settings\"\r\n                [items]=\"items\"\r\n                [useAltDown]=\"true\"\r\n                [maxDropDownHeight]=\"maxDropDownHeight\"\r\n                [disableTextEditor]=\"disableTextEditor\"\r\n                (mousedown)=\"inputMouseDown($event)\"\r\n                (itemSelect)=\"inputItemSelect($event)\"\r\n                (keydown)=\"inputKeyDown($event)\"></true-select>\r\n            </div>`,\r\n  styleUrls: ['./editor-select-true.component.scss']\r\n  })\r\nexport class EditorSelectTrueComponent implements IEditor, OnDestroy {\r\n\r\n  protected destroy$: Subject<boolean> = new Subject<boolean>();\r\n\r\n  private ie: boolean = false;\r\n  private valueChanged: boolean = false;\r\n  private height: number = 0;\r\n  private wasShown = false;\r\n\r\n  private initialized = false;\r\n\r\n  private _value: any = null;\r\n  public get value(): any {\r\n    return this._value;\r\n  }\r\n\r\n  public set value(v: any) {\r\n    this._value = v;\r\n    this.change.emit(v);\r\n  }\r\n\r\n  public get maxDropDownHeight(): string {\r\n    return this.state.settings.maxDropDownHeight;\r\n  }\r\n\r\n  public displayValue: string = '';\r\n\r\n  public disableTextEditor = false;\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: DropdownBaseComponent;\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  /**\r\n   * Список колонок выпадающего списка\r\n   */\r\n  private _columns: Column[] = null;\r\n  get columns(): Column[] {\r\n    if (this._columns === null) {\r\n      if (this.column.optionsColumns !== null) {\r\n        this._columns = this.column.optionsColumns;\r\n      } else {\r\n        this._columns = [new Column('name', 'name', 300, ColumnType.STRING)];\r\n      }\r\n    }\r\n    return this._columns;\r\n  }\r\n\r\n  /**\r\n   * Настройки грида в выпадающем списке\r\n   */\r\n  private _settings: GridSettings = null;\r\n  get settings() {\r\n    if (this._settings === null) {\r\n      this._settings = GridSettings.minimal();\r\n      this._settings.appearance.class = this.state.settings.appearance.class;\r\n      this._settings.appearance.enableFocusedAppearance = false;\r\n      this._settings.showHeader = false;\r\n      this._settings.searchDelay = 100;\r\n    }\r\n    return this._settings;\r\n  }\r\n\r\n  /**\r\n   * Данные выпадающего списка\r\n   */\r\n  private _items: any[] = null;\r\n  get items(): any[] {\r\n    if (this._items === null) {\r\n      if (this.column.optionsData instanceof Observable) {\r\n        // Подпись\r\n        const observable = <Observable<any>>this.column.optionsData;\r\n        observable.pipe(takeUntil(this.destroy$)).subscribe(data => {\r\n          this._items = data;\r\n        });\r\n      } else {\r\n        this._items = this.column.optionsData;\r\n      }\r\n    }\r\n    return this._items;\r\n  }\r\n\r\n  private _valueField: string = null;\r\n\r\n  public get valueField(): string {\r\n    if (this._valueField === null) {\r\n      this._valueField = this.columns[0].fieldName;\r\n    }\r\n    return this._valueField;\r\n  }\r\n\r\n  private _displayField: string = null;\r\n  public get displayField(): string {\r\n    if (this._displayField === null) {\r\n      this._displayField = this.columns[0].fieldName;\r\n    }\r\n    return this._displayField;\r\n  }\r\n\r\n  init(value: any, valueChanged: boolean, height: number, ie: boolean = false, wasShown: boolean = false) {\r\n    if (this.state.touchMode) {\r\n      this.input.popupPosition = 'MODAL';\r\n      this.disableTextEditor = true;\r\n    }\r\n\r\n    if (valueChanged) {\r\n      if (!this.disableTextEditor) {\r\n        this.displayValue = value;\r\n        this.valueChanged = true;\r\n      } else {\r\n        this.valueChanged = false;\r\n      }\r\n      this.change.emit(null);\r\n    } else {\r\n      // Без события об изменении\r\n      this._value = value;\r\n    }\r\n\r\n    this.wasShown = wasShown;\r\n    this.height = height;\r\n    this.ie = ie;\r\n  }\r\n\r\n  inputItemSelect(e: any) {\r\n    if (this.state.touchMode) {\r\n      this.commit.emit(this.value);\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  inputKeyDown(e: any) {\r\n\r\n    if (e.defaultPrevented) {\r\n      return;\r\n    }\r\n\r\n    if (e.keyCode === Keys.TAB) {\r\n      this.input.setValueFromDisplayed();\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      // По идее просто их должен отработать грид\r\n      e.stopPropagation();\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.touchMode) {\r\n        // На тач устройствах не будем фокусироваться на инпуте,\r\n        // нам достаточно показать форму для выбора в модальном режиме\r\n        if (!this.wasShown) {\r\n          setTimeout(() => this.input.showByTarget());\r\n        }\r\n      } else {\r\n        setTimeout(() => this.input.focus());\r\n      }\r\n      return;\r\n    }\r\n\r\n    this.input.focus();\r\n    setTimeout(() => {\r\n      this._renderer.setProperty(this.input.input.nativeElement, 'value', this.displayValue);\r\n      this._renderer.setProperty(this.input.input.nativeElement, 'selectionStart', this.displayValue.length);\r\n      this._renderer.setProperty(this.input.input.nativeElement, 'selectionEnd', this.displayValue.length);\r\n      this.input.displayValue = this.displayValue === null ? '' : this.displayValue;\r\n      this.input.inputInput();\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    }\r\n    return 'true-grid-editor-100p';\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  ngOnDestroy() {\r\n    // Если нас удаляют...\r\n    this.destroy$.next(true);\r\n    this.destroy$.unsubscribe();\r\n  }\r\n\r\n  constructor(protected _renderer: Renderer2) { }\r\n}\r\n"]}