UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

101 lines 13.9 kB
import * as tslib_1 from "tslib"; /** * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company. * @link https://truedirective.com/ * @license MIT */ import { Injectable } from '@angular/core'; import { Subject } from 'rxjs'; import { GridEvents } from './grid-events.class'; import { GridSelection } from './grid-selection.class'; import { InternationalizationService } from './internationalization/internationalization.service'; import { GridState } from '@true-directive/base'; import { DataQuery } from '@true-directive/base'; import { DOMUtils } from './common/dom-utils.class'; import { AxInject } from '@true-directive/base'; var GridStateService = /** @class */ (function (_super) { tslib_1.__extends(GridStateService, _super); function GridStateService(internationalization) { var _this = _super.call(this) || this; _this.internationalization = internationalization; _this.focusChangedSubscription = _this.selection.onFocusChanged.subscribe(function (v) { _this.layoutsHandler.updateLayoutSelections(v); _this.focusChanged(v); }); // При изменении выделения - обновить в лэйаутах. Но сейчас наоборот _this.selectionChangedSubscription = _this.selection.onSelectionChanged.subscribe(function (v) { _this.layoutsHandler.updateLayoutSelections(v); _this.events.selectEvent(v); }); _this.localeChangedSubscription = _this.internationalization.onLocaleChanged.subscribe(function (locale) { _this.dataSource.valueFormatter.setLocale(locale); }); return _this; } // Инициируем обновление данных со всеми пересчётами GridStateService.prototype.updateDataAsync = function () { var _this = this; var subject = new Subject(); if (this.settings.requestData) { // Необходимо запросить данные this.doQuery(subject); // НО! Нужно обновить колонки. this.events.columnsChangedEvent(); return subject; } // Запрашивать не нужно, считаем всё сами // Асинхронное обновление this.recalcData().then(function () { _this.fetchData(new DataQuery(_this._dataQueryCounter)); var rc; if (_this.dataSource.resultRows) { rc = _this.dataSource.resultRows.length; } subject.next(rc); subject.complete(); }); return subject; }; GridStateService.prototype.copySelectionToClipboard = function (withHeaders) { DOMUtils.copyToClipboard(this.getSelectedData(this.selection).toString(withHeaders, '\t')); }; GridStateService.prototype.exportToCSV = function (fileName, columnSeparator) { if (columnSeparator === void 0) { columnSeparator = ','; } DOMUtils.downloadCSV(fileName, this.dataToExport().toString(true, columnSeparator, true)); }; GridStateService.prototype.ngOnDestroy = function () { this.focusChangedSubscription.unsubscribe(); this.selectionChangedSubscription.unsubscribe(); this.localeChangedSubscription.unsubscribe(); }; /* // Важно обновить выделенные области в layouts protected subscribe() { this.events.onSelect.subscribe((cp: CellPosition) => { this.layoutsHandler.updateLayoutSelections(cp); }); } */ GridStateService.prototype.registerHandlers = function () { _super.prototype.registerHandlers.call(this); this.handlers['events'] = GridEvents; this.handlers['selection'] = GridSelection; }; tslib_1.__decorate([ AxInject('events'), tslib_1.__metadata("design:type", GridEvents) ], GridStateService.prototype, "events", void 0); tslib_1.__decorate([ AxInject('selection'), tslib_1.__metadata("design:type", GridSelection) ], GridStateService.prototype, "selection", void 0); GridStateService = tslib_1.__decorate([ Injectable() // @AxInjectConsumer , tslib_1.__metadata("design:paramtypes", [InternationalizationService]) ], GridStateService); return GridStateService; }(GridState)); export { GridStateService }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-state.service.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/grid-state.service.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 { Injectable, Injector, OnDestroy } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { Subject } from 'rxjs';\r\n\r\nimport { GridEvents } from './grid-events.class';\r\nimport { GridSelection } from './grid-selection.class';\r\nimport { InternationalizationService } from './internationalization/internationalization.service';\r\n\r\nimport { GridState, GridExporter } from '@true-directive/base';\r\nimport { Column } from '@true-directive/base';\r\nimport { CellPosition } from '@true-directive/base';\r\nimport { DataQuery } from '@true-directive/base';\r\nimport { CheckedChangedEvent, ValueChangedEvent, FilterShowEvent } from '@true-directive/base';\r\nimport { UIAction } from '@true-directive/base';\r\nimport { DOMUtils } from './common/dom-utils.class';\r\nimport { AxInject, AxInjectConsumer } from '@true-directive/base';\r\n\r\n@Injectable()\r\n// @AxInjectConsumer\r\nexport class GridStateService extends GridState implements OnDestroy {\r\n\r\n  focusChangedSubscription: any;\r\n  selectionChangedSubscription: any;\r\n  localeChangedSubscription: any;\r\n\r\n  @AxInject('events')\r\n  public events: GridEvents;\r\n\r\n  @AxInject('selection')\r\n  public selection: GridSelection;\r\n\r\n  // Инициируем обновление данных со всеми пересчётами\r\n  public updateDataAsync(): Observable<any> {\r\n    const subject = new Subject<any>();\r\n    if (this.settings.requestData) {\r\n      // Необходимо запросить данные\r\n      this.doQuery(subject);\r\n      // НО! Нужно обновить колонки.\r\n      this.events.columnsChangedEvent();\r\n      return subject;\r\n    }\r\n\r\n    // Запрашивать не нужно, считаем всё сами\r\n    // Асинхронное обновление\r\n    this.recalcData().then(() => {\r\n      this.fetchData(new DataQuery(this._dataQueryCounter));\r\n      let rc;\r\n      if (this.dataSource.resultRows) {\r\n        rc = this.dataSource.resultRows.length;\r\n      }\r\n      subject.next(rc);\r\n      subject.complete();\r\n    });\r\n\r\n    return subject;\r\n  }\r\n\r\n  public copySelectionToClipboard(withHeaders: boolean) {\r\n    DOMUtils.copyToClipboard(this.getSelectedData(this.selection).toString(withHeaders, '\\t')\r\n    );\r\n  }\r\n\r\n  public exportToCSV(fileName: string, columnSeparator: string = ',') {\r\n    DOMUtils.downloadCSV(fileName, this.dataToExport().toString(true, columnSeparator, true));\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.focusChangedSubscription.unsubscribe();\r\n    this.selectionChangedSubscription.unsubscribe();\r\n    this.localeChangedSubscription.unsubscribe();\r\n  }\r\n\r\n  /*\r\n  // Важно обновить выделенные области в layouts\r\n  protected subscribe() {\r\n    this.events.onSelect.subscribe((cp: CellPosition) => {\r\n      this.layoutsHandler.updateLayoutSelections(cp);\r\n    });\r\n  }\r\n  */\r\n \r\n  protected registerHandlers() {\r\n    super.registerHandlers();\r\n    this.handlers['events'] = GridEvents;\r\n    this.handlers['selection'] = GridSelection;\r\n  }\r\n\r\n  constructor(public internationalization: InternationalizationService) {\r\n    super();\r\n\r\n    this.focusChangedSubscription = (<GridSelection>this.selection).onFocusChanged.subscribe(v => {\r\n      this.layoutsHandler.updateLayoutSelections(v);\r\n      this.focusChanged(v);\r\n    });\r\n\r\n    // При изменении выделения - обновить в лэйаутах. Но сейчас наоборот\r\n    this.selectionChangedSubscription = (<GridSelection>this.selection).onSelectionChanged.subscribe(v => {\r\n      this.layoutsHandler.updateLayoutSelections(v);\r\n      this.events.selectEvent(v);\r\n    });\r\n\r\n    this.localeChangedSubscription = this.internationalization.onLocaleChanged.subscribe(locale => {\r\n      this.dataSource.valueFormatter.setLocale(locale);\r\n    });\r\n  }\r\n}\r\n"]}